成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

開發 后端
想打包多個程序需要重新操作一遍,所以對于一個程序員來說,這是一個忍無可忍的事情。基于此,我基于pyinstaller寫了個小小的批量打包程序。

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

責任編輯:龐桂玉 來源: 早起Python
相關推薦

2021-03-31 13:28:17

開源工具Python編程語言

2021-05-14 17:09:21

Python工具代碼

2021-02-23 09:50:42

PythonJSWeb SSH

2021-02-10 09:34:40

Python文件的壓縮PyCharm

2010-03-25 15:52:51

Python程序

2011-03-18 19:05:31

QQQtWidget

2020-08-20 14:15:11

工具代碼開發

2011-01-06 10:39:25

.NET程序打包

2021-05-07 21:53:44

Python 程序pyinstaller

2021-05-08 12:30:03

Pythonexe代碼

2012-02-13 13:36:27

Java

2012-06-25 12:33:12

Java日志切割

2011-12-07 12:01:31

ibmdw

2024-02-20 08:51:56

PythonFlask工具

2022-01-11 09:59:23

Python關機程序文件

2010-06-04 17:48:20

Linux編程工具

2024-10-11 12:00:00

Python批量文件操作

2010-11-29 13:17:00

Sybase批量操作

2016-09-12 14:05:27

PythonPython解釋器Web

2010-11-24 11:13:07

MySQL批量導入
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日本一本在线 | 亚洲精品国产a久久久久久 午夜影院网站 | 国产馆 | a在线免费观看视频 | 伊人91在线 | 91精品国产91久久久久久吃药 | 久久噜| 性xxxxx| 精品一二三区在线观看 | 91精品午夜窝窝看片 | 久草日韩 | 成人精品视频在线 | 午夜免费看视频 | 羞羞视频免费观看 | 国产综合视频 | 精品一区二区三区不卡 | 91精品一区二区三区久久久久 | 国产精品一区二区久久 | 美女视频一区 | 羞羞免费网站 | 9porny九色视频自拍 | 国产精品久久久久久久久免费丝袜 | 国产精品久久久久久久久久免费看 | 黄色亚洲 | 黄片毛片 | 人人种亚洲| 久久免费精品视频 | 亚洲人精品| 久久乐国产精品 | 日韩欧美在线观看视频 | 欧美精品中文字幕久久二区 | 精品一区二区在线观看 | 久久久资源 | 91.xxx.高清在线 | 黄网在线观看 | 精品在线观看一区二区 | 久久久毛片 | 色综合视频| 国产精品国产三级国产aⅴ中文 | 亚洲国产aⅴ成人精品无吗 国产精品永久在线观看 | 欧美成人免费在线视频 |