python GUI庫圖形界面開發之pyinstaller打包python程序為exe安裝文件
本文介紹一個exe打包工具pyinstaller,使用非常簡單、方便,而且還跨平臺。
軟硬件環境
Windows 10 64bit PyQt5 Anaconda with python 3.6.5 pyinstaller apscheduler sqlalchemypyinstaller安裝命令行中執行
pip install pyinstallerpyinstaller打包exe
示例還是以之前的為例,解壓進入工程目錄,命令行執行打包命令
pyinstaller -F --distpath release main.py
其中release是目標文件夾,main.py是工程入口文件,-F表示生成一個可執行文件。
pyinstaller的打包參數很多,需要的話通過help來查看
pyinstaller -hsubprocess打包問題
在打包包含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,stdin=subprocess.DEVNULL, stdout=subprocess.PIPE, stderr=subprocess.STDOUT,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_metadatadatas = copy_metadata(’apscheduler’)
最后執行打包命令
pyinstaller -F --clean --additional-hooks-dir hooks --distpath release main.pysqlalchemy打包問題
在用pyinstaller打包一個使用了sqlalchemy庫的python3工程中,碰到了打包后的可執行文件報錯的問題,如下圖所示
解決方案是,將sqlalchemy.dialects中的mysql引入,然后采用mysql+pymysql的方式打開數據庫,代碼如下
import pymysqlfrom sqlalchemy import create_enginefrom sqlalchemy.orm import sessionmakerfrom sqlalchemy.dialects import mysqlusername = ’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安裝文件的其實操作就算完成了,如果出現其它問題請直接聯系我們,更多關于這方面的相關知識請查看下面的相關鏈接
相關文章: