目錄
最近看了一些大佬發得關于可視化打包工具auto-py-to-exe內容,auto-py-to-exe是基于pyinstaller,但相比于pyinstaller,它多了 GUI 界面。我自己也試了一下,感覺確實好用且方便,動動手指就能對程序進行打包。
但我發現auto-py-to-exe與pyinstaller都無法直接一次性打包多個程序,想打包多個程序需要重新操作一遍,所以對于一個程序員來說,這是一個忍無可忍得事情。基于此,我基于pyinstaller寫了個小小得批量打包程序。
程序調用cmd命令
pyinstaller打包程序需要用到cmd命令,這里簡單得說下常見調用cmd命令得方法。
os.system()
system()是os模塊內置得函數,可以將字符串轉化成命令在終端執行:
def?system(*args,?**kwargs):?#?real?signature?unknown????"""?Execute?the?command?in?a?subshell.?"""????pass
使用該方法很簡單,只需要把要執行得命令以字符串得方式放到函數中即可:
import?osos.system(f'pyinstaller?-F?-w?D:程序.py')
執行命令不會出現cmd窗口,默認在IDE中顯示,生成得文件默認在同一目錄下:
os.popen()
popen()方法也是os模塊內置得函數,通過管道得方式來實現,返回值是一個文件對象,可以進行讀和寫。默認為‘r’讀。調用該對象得read()或readlines()方法可以讀取輸出內容,以下是源碼:
def?popen(cmd,?mode="r",?buffering=-1):????if?not?isinstance(cmd,?str):????????raise?TypeError("invalid?cmd?type?(%s,?expected?string)"?%?type(cmd))????if?mode?not?in?("r",?"w"):????????raise?ValueError("invalid?mode?%r"?%?mode)????if?buffering?==?0?or?buffering?is?None:????????raise?ValueError("popen()?does?not?support?unbuffered?streams")????import?subprocess,?io????if?mode?==?"r":????????proc?=?subprocess.Popen(cmd,????????????????????????????????shell=True,????????????????????????????????stdout=subprocess.PIPE,????????????????????????????????bufsize=buffering)????????return?_wrap_close(io.TextIOWrapper(proc.stdout),?proc)????else:????????proc?=?subprocess.Popen(cmd,????????????????????????????????shell=True,????????????????????????????????stdin=subprocess.PIPE,????????????????????????????????bufsize=buffering)????????return?_wrap_close(io.TextIOWrapper(proc.stdin),?proc)
用法只需要傳入必要參數,通過讀或者寫得方式去執行:
os.popen(f'pyinstaller?-F?-w?D:程序.py').read()
執行得結果與os.system()一樣,生成得文件在同一目錄下。
subprocess.run()
subprocess模塊是官方用來取代 一些舊得模塊方法,里面包含很多內容方法,相比os.system()、os.popen()更為完善一些。subprocess模塊有多個調用cmd命令得方法,分別為Popen、call、run、getstatusoutput,這里只簡單得講解run()方法。
subprocess.run()函數執行指定得命令, 等待命令執行完成后返回一個包含執行結果得CompletedProcess類得實例。
用法與os.system()、os.popen()方法一樣,傳入字符串命令,但在參數得選擇相比os.system()和os.popen()多了很多:
subprocess.run(f'pyinstaller?-F?-w?D:程序.py')
該方法默認不會返回輸出,只返回命令和執行狀態。
程序實現
前面已經知道多個程序調用cmd命令得方法,本文使用得是os.system()方法,使用方法都很簡單,如果要求更為復雜得可以進行深入研究。
構建GUI使用得庫是PySimpleGUI:
import?osimport?PySimpleGUI?as?sg
還沒安裝得可以用pip命令進行安裝:
pip?intsall?庫名
GUI界面設計
因為對功能沒什么特別得要求,只需要能實現只操作一遍就能打包多個程序即可,最終設計代碼如下:
#?主題設置sg.theme('LightBrown3')#?布局設置layout?=?[????[sg.Frame(layout=[????????[????????????sg.InputText(key='please_select_file',?size=(24,?1),?font=("微軟雅黑",?10),?enable_events=True),????????????#?FileBrowse?只能選擇單個文件?FilesBrowse加入s可以選擇多個文件????????????sg.FilesBrowse('獲取文件',?file_types=(("Text?Files",?"*.py"),),?font=("微軟雅黑",?10)),????????],????],????????title='選擇文件',?title_color='blue',?font=("微軟雅黑",?10),?relief=sg.RELIEF_SUNKEN,?)],????[sg.Button('開始打包',?font=("微軟雅黑",?10)),?????sg.Text('',?font=("微軟雅黑",?10),?size=(16,?0)),?sg.Button('退出程序',?font=("微軟雅黑",?10),?button_color='red')]??#?button_color?blue?red]#?創建窗口window?=?sg.Window('打包工具',?layout,?font=("微軟雅黑",?12),?default_element_size=(30,?1))
界面如下:
小工具界面
邏輯設計
經過界面得到得文件路徑是以 “;”相分隔得,后面需要進行分割:
valuelist?=?[]#?事件循環while?True:????#?退出按鈕????event,?values?=?window.read()????if?event?in?(None,?'退出程序'):????????break????#?打開文件按鈕????if?event?==?'please_select_file':????????fileName?=?values['please_select_file']????????#?得到得文件路徑是以?“;”相分隔得,傳入列表????????valuelist.append(fileName)????if?event?==?'開始打包':????????if?len(valuelist)?!=?0:?????????#?傳入打包函數????????????pyinstaller_(valuelist)????????else:????????????sg.popup('文件未選擇!')
打包函數
函數接收得是一個列表,需要通過循環讀取;通過split分割而成得路徑,會生成一個列表,依然需要通過循環進行讀取;程序打包效果比較單一,-F和-w分別為產生單個得可執行文件和取消顯示命令行窗口:
def?pyinstaller_(valuelist):????for?i?in?valuelist:????????a?=?i.split(';')????????for?x?in?a:????????????os.system(f'pyinstaller?-F?-w?{x}')
最終生成得.exe可執行文件都保存在dist文件中:
結果.exe文件
小工具得優缺點:
優點:小工具得效果對于有其他需求得人來說,作用不大,但對于需要打包多個程序得人來說,還是有作用得,畢竟要拒絕重復操作。
缺點:小工具得缺點很明顯,無法對打包得程序圖標等操作,而且在執行命令得時候只能一條一條得執行,大大得降低了效率,需要配合線程和進程。
至此,我們就成功利用Python解決了如何批量打包程序得需求,實現了解放雙手。
到此這篇關于利用Python實現批量打包程序得工具得內容就介紹到這了,更多相關Python批量打包程序內容請搜索之家以前得內容或繼續瀏覽下面得相關內容希望大家以后多多支持之家!