日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

利用Python實現批量打包程序的工具_python

作者:鋒小刀 ? 更新時間: 2022-09-19 編程語言

最近看了一些大佬發的關于可視化打包工具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?os
os.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?os
import?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解決了如何批量打包程序的需求,實現了解放雙手。

原文鏈接:https://mp.weixin.qq.com/s/3WS957VHbThmw7oE44ungg

欄目分類
最近更新