本文介紹一個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,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_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安裝檔案的其實操作就算完成了,如果出現其它問題請直接聯系我們,更多關于這方面的相關知識請檢視下面的相關連結