python GUI庫圖形界面開發(fā)之pyinstaller打包python程序為exe安裝文件
本文介紹一個exe打包工具pyinstaller,使用非常簡單、方便,而且還跨平臺。
軟硬件環(huán)境
Windows 10 64bit PyQt5 Anaconda with python 3.6.5 pyinstaller apscheduler sqlalchemypyinstaller安裝命令行中執(zhí)行
pip install pyinstallerpyinstaller打包exe
示例還是以之前的為例,解壓進入工程目錄,命令行執(zhí)行打包命令
pyinstaller -F --distpath release main.py
其中release是目標文件夾,main.py是工程入口文件,-F表示生成一個可執(zhí)行文件。
pyinstaller的打包參數(shù)很多,需要的話通過help來查看
pyinstaller -hsubprocess打包問題
在打包包含subprocess.Popen時發(fā)現(xiàn),加上參數(shù)--noconsole時產(chǎn)生的exe文件在運行的時候,進程并沒有正確運行。比如需要利用subprocess.Popen創(chuàng)建一個進程去執(zhí)行一個命令行操作,
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,可以運行,不過查看進程并沒有如預期正確地工作。
解決方法是在創(chuàng)建進程時,加上startupinfo參數(shù),如下
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打包的時候,出現(xiàn)了如下錯誤
解決方法是,編輯文件/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的版本號,視實際情況修改。
接下來創(chuàng)建一個名稱為hook-ctypes.macholib.py,內(nèi)容如下
# -*- coding: utf-8 -*-from PyInstaller.utils.hooks import copy_metadatadatas = copy_metadata(’apscheduler’)
最后執(zhí)行打包命令
pyinstaller -F --clean --additional-hooks-dir hooks --distpath release main.pysqlalchemy打包問題
在用pyinstaller打包一個使用了sqlalchemy庫的python3工程中,碰到了打包后的可執(zhí)行文件報錯的問題,如下圖所示
解決方案是,將sqlalchemy.dialects中的mysql引入,然后采用mysql+pymysql的方式打開數(shù)據(jù)庫,代碼如下
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)
執(zhí)行pyinstaller打包命令
pyinstaller -F --clean --distpath shark main.py
好了,至此pyinstaller打包python程序為exe安裝文件的其實操作就算完成了,如果出現(xiàn)其它問題請直接聯(lián)系我們,更多關(guān)于這方面的相關(guān)知識請查看下面的相關(guān)鏈接
相關(guān)文章:
1. XML入門的常見問題(三)2. HTTP協(xié)議常用的請求頭和響應頭響應詳解說明(學習)3. ASP將數(shù)字轉(zhuǎn)中文數(shù)字(大寫金額)的函數(shù)4. XML在語音合成中的應用5. .NET Framework各版本(.NET2.0 3.0 3.5 4.0)區(qū)別6. jscript與vbscript 操作XML元素屬性的代碼7. 不要在HTML中濫用div8. php使用正則驗證密碼字段的復雜強度原理詳細講解 原創(chuàng)9. ASP基礎(chǔ)入門第四篇(腳本變量、函數(shù)、過程和條件語句)10. HTML5實戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)
