
來源:AirPython
作者:星安果
大家好,我是安果!
我們都知道 Python 可以用來開發(fā)桌面應用,一旦功能開發(fā)完成,最后打包的可執(zhí)行文件體積大,并且使用 Python 開發(fā)桌面應用周期相對較長
假如想快速開發(fā)一款 PC 端的桌面應用,推薦使用 Aardio + Python 搭配的方式進行開發(fā)
Aardio 是一款專注于 Windows 桌面端的軟件開發(fā),適用于快速開發(fā)一些自用的 PC 端桌面工具,并且它支持與 Python、JS、Golang 等主流語言進行混合編程
它是一款免費的開發(fā)工具,簡單易學,支持多線程,具有輕巧、快速開發(fā)的特征
PS:Aardio 僅適用于開發(fā) Windows 桌面應用,不具有跨平臺性
首先,從官網下載軟件后打開,點擊左上角「 新建工程 」,選擇「 空白工程 」模板,輸入項目名稱,點擊創(chuàng)建按鈕,一個空白工程被創(chuàng)建完成了
PS:Aardio 軟件內置了很多界面模板、程序模板,可以根據需求自行選擇
然后,從軟件左下角的「 界面控件 」中選擇 2 個控件,一個靜態(tài)文本 Label、一個按鈕 Button,接著設置控件的位置、大小、屬性
控件大小及區(qū)域:選擇控件后,在中間面板區(qū)域,用鼠標左鍵拖動來設置控件位置、控件大小
控件屬性:選中某一個控件后,在軟件右側區(qū)域「 屬性 」中設置控件的屬性
雙擊按鈕控件會從「 設計視圖 」切換到「 代碼視圖 」,并在代碼中生成按鈕的點擊監(jiān)聽事件
PS:也可以通過工具欄「 切換 」按鈕或快捷鍵「 Ctrl +U 」切換兩種視圖
接著,在按鈕點擊事件中編寫代碼,使用窗體對象內置的方法 msgbox() 彈出一個提示對話框
import win.ui;
/*DSG{{*/
mainForm = win.form(text="aardio工程8";right=959;bottom=591)
mainForm.add(
button={cls="button";text="彈出 Hello World";left=320;top=120;right=568;bottom=184;z=2};
static={cls="static";text="Hello";left=80;top=120;right=240;bottom=168;notify=1;transparent=1;z=1}
)
/*}}*/
//設置按鈕的點擊事件
mainForm.button.oncommand = function(id,event){
//彈出一個提示框
mainForm.msgbox("Hello World,Arrdio!")
}
mainForm.show();
return win.loopMessage();
最后,點擊工具欄中的「 發(fā)布」按鈕或快捷鍵 F7 生成可執(zhí)行包
需要注意的是,如果彈出需要更新 Windows Defender 實時保護排除目錄,點擊默認按鈕即可
雖然 Aardio 提供了豐富的 API,很多功能可以取代 Python 來直接實現(xiàn),但是熟練掌握 Python 的小伙伴對于 Aardio 語法可能不太能適應
假設我們用 Python 寫了一個簡單的爬蟲,使用 BeautifulSoup 爬取網頁標題
from urllib.request import urlopen
from urllib.error import HTTPError
from bs4 import BeautifulSoup
def getTitle(url):
"""爬蟲獲取網頁標題"""
try:
html = urlopen(url)
except HTTPError as e:
return None
try:
bsObj = BeautifulSoup(html.read(), "html.parser")
title = bsObj.head.title.string
except AttributeError as e:
return None
return title
下面我們在 Aardio 編寫具體的業(yè)務邏輯
首先,在 Aardio 中添加 2 個文本框和一個觸發(fā)按鈕
接著,為按鈕設置點擊事件調用 Python 腳本
在 Aardio 中調用 Python 包含 4 個步驟
import py3;
... //添加調用函數(shù)的路徑,string指pycode為字符類型 pyCode = string.load("rescallpy_pro.py"); //執(zhí)行pycode py3.exec(pyCode);
mainForm.btn.oncommand = function(id,event){ //調用函數(shù),在main中調用函數(shù)getTitle() var result = py3.main.getTitle(content);
mainForm.result.text = result; //提示彈框 mainForm.msgbox(result);
}
mainForm.show(); return win.loopMessage();
如果直接運行程序會報錯缺少依賴的錯誤,原因是 Python 腳本中引用了 BS4 的依賴
這時,我們需要先執(zhí)行發(fā)布操作生成可執(zhí)行文件及 py3 的文件夾
注意:py3 文件夾在安裝 py3 依賴的時候自動生成
最后,將 BS4 的依賴目錄拷貝到「 /dist/lib/py3/.res/」 目錄下
比如
# bs4 依賴目錄
C:UsersxingagAppDataLocalProgramsPythonPython37Libsite-packagesbs4
# bs4放置到的目標文件夾
C:UsersxingagDesktopaardiosoftwareprojectcallpydistlibpy3.res
運行項目,在輸入框中輸入一個網址,點擊按鈕,會將爬取的結果展示到結果輸入框,并且彈出一個提示框
PS:由于項目涉及到 Python 外部依賴,分享 EXE 可執(zhí)行文件時,需要將 lib 文件夾一同壓縮打包出去
本篇文章介紹了 Aardio 的基本用法及調用 Python 腳本的具體流程
實際上,Aardio 的功能非常強大,它在文件操作、操作系統(tǒng)、音視頻、數(shù)據庫、網絡應用、高級應用控件、自動化等都有對應的 API,大家可以自行拓展
數(shù)據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉換:從基礎用法到實戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據處理中,日期格式轉換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關聯(lián)查詢效率:打破 “拆分必慢” 的認知誤區(qū) 在 MySQL 數(shù)據庫管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據分析師:表結構數(shù)據 “獲取 - 加工 - 使用” 全流程的賦能者 表結構數(shù)據(如數(shù)據庫表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預期算子的內涵、作用與應用解析 動態(tài)隨機一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數(shù)據分析師:解鎖表結構數(shù)據特征價值的專業(yè)核心 表結構數(shù)據(以 “行 - 列” 規(guī)范存儲的結構化數(shù)據,如數(shù)據庫表、Excel 表、 ...
2025-09-17Excel 導入數(shù)據含缺失值?詳解 dropna 函數(shù)的功能與實戰(zhàn)應用 在用 Python(如 pandas 庫)處理 Excel 數(shù)據時,“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗與 t 檢驗:差異、適用場景與實踐應用 在數(shù)據分析與統(tǒng)計學領域,假設檢驗是驗證研究假設、判斷數(shù)據差異是否 “ ...
2025-09-16CDA 數(shù)據分析師:掌控表格結構數(shù)據全功能周期的專業(yè)操盤手 表格結構數(shù)據(以 “行 - 列” 存儲的結構化數(shù)據,如 Excel 表、數(shù)據 ...
2025-09-16MySQL 執(zhí)行計劃中 rows 數(shù)量的準確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調優(yōu)中,EXPLAIN執(zhí)行計劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對象的 text 與 content:區(qū)別、場景與實踐指南 在 Python 進行 HTTP 網絡請求開發(fā)時(如使用requests ...
2025-09-15CDA 數(shù)據分析師:激活表格結構數(shù)據價值的核心操盤手 表格結構數(shù)據(如 Excel 表格、數(shù)據庫表)是企業(yè)最基礎、最核心的數(shù)據形態(tài) ...
2025-09-15Python HTTP 請求工具對比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請求(如接口調用、數(shù)據爬取 ...
2025-09-12解決 pd.read_csv 讀取長浮點數(shù)據的科學計數(shù)法問題 為幫助 Python 數(shù)據從業(yè)者解決pd.read_csv讀取長浮點數(shù)據時的科學計數(shù)法問題 ...
2025-09-12CDA 數(shù)據分析師:業(yè)務數(shù)據分析步驟的落地者與價值優(yōu)化者 業(yè)務數(shù)據分析是企業(yè)解決日常運營問題、提升執(zhí)行效率的核心手段,其價值 ...
2025-09-12用 SQL 驗證業(yè)務邏輯:從規(guī)則拆解到數(shù)據把關的實戰(zhàn)指南 在業(yè)務系統(tǒng)落地過程中,“業(yè)務邏輯” 是連接 “需求設計” 與 “用戶體驗 ...
2025-09-11塔吉特百貨孕婦營銷案例:數(shù)據驅動下的精準零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當下,精準營銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據分析師與戰(zhàn)略 / 業(yè)務數(shù)據分析:概念辨析與協(xié)同價值 在數(shù)據驅動決策的體系中,“戰(zhàn)略數(shù)據分析”“業(yè)務數(shù)據分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據聚類分析:從操作實踐到業(yè)務價值挖掘 在數(shù)據分析場景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數(shù)據中挖 ...
2025-09-10統(tǒng)計模型的核心目的:從數(shù)據解讀到決策支撐的價值導向 統(tǒng)計模型作為數(shù)據分析的核心工具,并非簡單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10