python GUI庫圖形介面開發之pyinstaller打包python程式為exe安裝檔案
本文介紹一個exe打包工具pyinstaller,使用非常簡單、方便,而且還跨平臺。
軟硬體環境
- Windows 10 64bit
- PyQt5
- Anaconda with python 3.6.5
- pyinstaller
- apscheduler
- sqlalchemy
pyinstaller安裝
命令列中執行
pip install pyinstaller
pyinstaller打包exe
示例還是以之前的為例,解壓進入工程目錄,命令列執行打包命令
pyinstaller -F --distpath release main.py
其中release是目標資料夾,main.py是工程入口檔案,-F表示生成一個可執行檔案。
pyinstaller的打包引數很多,需要的話通過help來檢視
pyinstaller -h
subprocess打包問題
在打包包含subprocess.Popen時發現,加上引數--noconsole時產生的exe檔案在執行的時候,程序並沒有正確執行。比如需要利用subprocess.Popen建立一個程序去執行一個命令列操作,
mProcess = subprocess.Popen(cmd,stdin=subprocess.DEVNULL,stdout=subprocess.PIPE,stderr=subprocess.STDOUT,universal_newlines=True)
pyinstaller打包操作命令如下
pyinstaller -F --noconsole --clean --distpath release main.py
打包後生成的exe,可以執行,不過檢視程序並沒有如預期正確地工作。
解決方法是在建立程序時,加上startupinfo引數,如下
si = subprocess.STARTUPINFO()
si.dwFlags |= subprocess.STARTF_USESHOWWINDOW
mProcess = subprocess.Popen(cmd,universal_newlines=True,startupinfo=si)
問題完美解決,具體可以參考文末的資料
apscheduler打包問題
專案中用到了apscheduler這個庫,用來做定時任務非常的好,使用也很簡單,不過在pyinstaller打包的時候,出現瞭如下錯誤
解決方法是,編輯檔案/usr/local/lib/python3.5/dist-packages/apscheduler/__init__.py
# These will be removed in APScheduler 4.0.
# release = __import__('pkg_resources').get_distribution('APScheduler').version.split('-')[0]
# version_info = tuple(int(x) if x.isdigit() else x for x in release.split('.'))
# version = __version__ = '.'.join(str(x) for x in version_info[:3])
release = (3,3,1)
version_info = '3.3.1'
version = '3.3.1'
3.3.1是我安裝的apscheduler的版本號,視實際情況修改。
接下來建立一個名稱為hook-ctypes.macholib.py,內容如下
# -*- coding: utf-8 -*- from PyInstaller.utils.hooks import copy_metadata datas = copy_metadata('apscheduler')
最後執行打包命令
pyinstaller -F --clean --additional-hooks-dir hooks --distpath release main.py
sqlalchemy打包問題
在用pyinstaller打包一個使用了sqlalchemy庫的python3工程中,碰到了打包後的可執行檔案報錯的問題,如下圖所示
解決方案是,將sqlalchemy.dialects中的mysql引入,然後採用mysql+pymysql的方式開啟資料庫,程式碼如下
import pymysql from sqlalchemy import create_engine from sqlalchemy.orm import sessionmaker from sqlalchemy.dialects import mysql username = 'xugaoxiang' passwd = '123456' server = '192.168.0.100' port = '3306' dbname = 'djdb' cmd_connect = 'mysql+pymysql://{}:{}@{}:{}/{}'.format(username,passwd,server,port,dbname) engine = create_engine(cmd_connect)
執行pyinstaller打包命令
pyinstaller -F --clean --distpath shark main.py
好了,至此pyinstaller打包python程式為exe安裝檔案的其實操作就算完成了,如果出現其它問題請直接聯絡我們,更多關於這方面的相關知識請檢視下面的相關連結