您好,登錄后才能下訂單哦!
這篇文章主要介紹“怎么利用Python實現批量打包程序的工具”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“怎么利用Python實現批量打包程序的工具”文章能幫助大家解決問題。
pyinstaller打包程序需要用到cmd命令,這里簡單的說下常見調用cmd命令的方法。
system()是os模塊內置的函數,可以將字符串轉化成命令在終端執行:
def system(*args, **kwargs): # real signature unknown """ Execute the command in a subshell. """ pass
使用該方法很簡單,只需要把要執行的命令以字符串的方式放到函數中即可:
import os os.system(f'pyinstaller -F -w D:\程序.py')
執行命令不會出現cmd窗口,默認在IDE中顯示,生成的文件默認在同一目錄下:
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模塊是官方用來取代 一些舊的模塊方法,里面包含很多內容方法,相比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 os import PySimpleGUI as sg
還沒安裝的可以用pip命令進行安裝:
pip intsall 庫名
因為對功能沒什么特別的要求,只需要能實現只操作一遍就能打包多個程序即可,最終設計代碼如下:
# 主題設置 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實現批量打包程序的工具”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。