利用Python實現(xiàn)批量打包程序的工具
最近看了一些大佬發(fā)的關于可視化打包工具auto-py-to-exe文章,auto-py-to-exe是基于pyinstaller,但相比于pyinstaller,它多了 GUI 界面。我自己也試了一下,感覺確實好用且方便,動動手指就能對程序進行打包。
但我發(fā)現(xiàn)auto-py-to-exe與pyinstaller都無法直接一次性打包多個程序,想打包多個程序需要重新操作一遍,所以對于一個程序員來說,這是一個忍無可忍的事情。基于此,我基于pyinstaller寫了個小小的批量打包程序。
程序調(diào)用cmd命令
pyinstaller打包程序需要用到cmd命令,這里簡單的說下常見調(diào)用cmd命令的方法。
os.system()
system()是os模塊內(nèi)置的函數(shù),可以將字符串轉(zhuǎn)化成命令在終端執(zhí)行:
def?system(*args,?**kwargs):?#?real?signature?unknown ????"""?Execute?the?command?in?a?subshell.?""" ????pass
使用該方法很簡單,只需要把要執(zhí)行的命令以字符串的方式放到函數(shù)中即可:
import?os os.system(f'pyinstaller?-F?-w?D:\程序.py')
執(zhí)行命令不會出現(xiàn)cmd窗口,默認在IDE中顯示,生成的文件默認在同一目錄下:

os.popen()
popen()方法也是os模塊內(nèi)置的函數(shù),通過管道的方式來實現(xiàn),返回值是一個文件對象,可以進行讀和寫。默認為‘r’讀。調(diào)用該對象的read()或readlines()方法可以讀取輸出內(nèi)容,以下是源碼:
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)
用法只需要傳入必要參數(shù),通過讀或者寫的方式去執(zhí)行:
os.popen(f'pyinstaller?-F?-w?D:\程序.py').read()
執(zhí)行的結果與os.system()一樣,生成的文件在同一目錄下。
subprocess.run()
subprocess模塊是官方用來取代 一些舊的模塊方法,里面包含很多內(nèi)容方法,相比os.system()、os.popen()更為完善一些。subprocess模塊有多個調(diào)用cmd命令的方法,分別為Popen、call、run、getstatusoutput,這里只簡單的講解run()方法。
subprocess.run()函數(shù)執(zhí)行指定的命令, 等待命令執(zhí)行完成后返回一個包含執(zhí)行結果的CompletedProcess類的實例。
用法與os.system()、os.popen()方法一樣,傳入字符串命令,但在參數(shù)的選擇相比os.system()和os.popen()多了很多:
subprocess.run(f'pyinstaller?-F?-w?D:\程序.py')
該方法默認不會返回輸出,只返回命令和執(zhí)行狀態(tài)。
程序?qū)崿F(xiàn)
前面已經(jīng)知道多個程序調(diào)用cmd命令的方法,本文使用的是os.system()方法,使用方法都很簡單,如果要求更為復雜的可以進行深入研究。
構建GUI使用的庫是PySimpleGUI:
import?os import?PySimpleGUI?as?sg
還沒安裝的可以用pip命令進行安裝:
pip?intsall?庫名
GUI界面設計
因為對功能沒什么特別的要求,只需要能實現(xiàn)只操作一遍就能打包多個程序即可,最終設計代碼如下:
#?主題設置
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
]
#?創(chuàng)建窗口
window?=?sg.Window('打包工具',?layout,?font=("微軟雅黑",?12),?default_element_size=(30,?1))
界面如下:

小工具界面
邏輯設計
經(jīng)過界面得到的文件路徑是以 “;”相分隔的,后面需要進行分割:
valuelist?=?[]
#?事件循環(huán)
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:
?????????#?傳入打包函數(shù)
????????????pyinstaller_(valuelist)
????????else:
????????????sg.popup('文件未選擇!')
打包函數(shù)
函數(shù)接收的是一個列表,需要通過循環(huán)讀??;通過split分割而成的路徑,會生成一個列表,依然需要通過循環(huán)進行讀??;程序打包效果比較單一,-F和-w分別為產(chǎn)生單個的可執(zhí)行文件和取消顯示命令行窗口:
def?pyinstaller_(valuelist):
????for?i?in?valuelist:
????????a?=?i.split(';')
????????for?x?in?a:
????????????os.system(f'pyinstaller?-F?-w?{x}')
最終生成的.exe可執(zhí)行文件都保存在dist文件中:

結果.exe文件
小工具的優(yōu)缺點:
優(yōu)點:小工具的效果對于有其他需求的人來說,作用不大,但對于需要打包多個程序的人來說,還是有作用的,畢竟要拒絕重復操作。
缺點:小工具的缺點很明顯,無法對打包的程序圖標等操作,而且在執(zhí)行命令的時候只能一條一條的執(zhí)行,大大的降低了效率,需要配合線程和進程。
至此,我們就成功利用Python解決了如何批量打包程序的需求,實現(xiàn)了解放雙手。
到此這篇關于利用Python實現(xiàn)批量打包程序的工具的文章就介紹到這了,更多相關Python批量打包程序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python調(diào)用釘釘自定義機器人的實現(xiàn)
這篇文章主要介紹了Python調(diào)用釘釘自定義機器人的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-01-01
探索Python庫coconut輕松地編寫函數(shù)式代碼實例
本文將介紹Python Coconut的基本概念、語法特性和實際應用,同時提供豐富的示例代碼,以幫助大家更好地理解和應用這個強大的工具2024-01-01
使用python實現(xiàn)男神女神顏值打分系統(tǒng)(推薦)
這篇文章主要介紹了用python做一個男神女神顏值打分系統(tǒng)(程序分析見注釋),需要的朋友可以參考下2019-10-10

