這是一個很長的故事,嫌長的直接看最后的結論
事情經過
上周接了個需求,寫了個小工具給客戶,他要求打包成exe文件,這當然不是什么難事。因為除了寫Python的,絕大多數人電腦里都沒有Python編譯器,所以打包成exe,讓用戶(windows)雙擊就可以打開,也算是必備技能了。
直接用Pyinstaller,打開cmder:
(-F 是打包成一個文件,-w是不出現調試窗口,因為我的小工具里有GUI,所以不用默認的調試窗口)
等了好久,終於完成打包,一看文件,嚯,200M!怪不得打包了這么久...
上網查了下資料,有人說,Anaconda里內置了很多庫,打包的時候打包了很多不必要的模塊進去,要用純凈的Python來打包。
有點道理,想着裝虛擬機時間更長,准備拿出閑置的筆記本,重新裝個Python來打包。
可剛巧我最近在學flask的時候,用到pipenv,雖然還不懂pipenv的強大之處,但知道它是個管理虛擬環境和包的工具,於是想着能不能用pipenv來創建一個新的python編譯器以運行pyinstaller進行打包。
於是趕緊上網查了一下,pipenv pyinstaller,沒有搜到有用的信息,干脆自己試一試,反正pipenv操作不麻煩。
打開cmder:
打包完成,一看大小,11M!成功!
后來因為客戶改了需求,我又改了一下源代碼,然后換了個目錄用pipenv重新打包,結果打包完又變回200M!嘗試了無數次,怎么也回不到過去的20M!我都懷疑之前的20M是我的幻覺了。
不過無論如何要先交差,200M的“小“工具,用戶體驗肯定不行,所以我就用排除法,看看是哪個模塊占的體積大,再想辦法優化。最先懷疑的是GUI,我幾乎毫不猶豫地認定是它,我用的是PySimpleGUI(強烈推薦,基於tkinter),先把PySimpleGUI的內容注釋掉,再進行打包,你們猜打包完有多大?
198M!
可直接聯系客服QQ交代需求:953586085
看來是我錯怪他了,經過幾次排除,發現了罪魁禍首就是:fake_useragent
這個庫是用來偽裝請求頭的,主要是我懶得復制user-agent,所以問題不大,把fake_useragent注釋掉,自己手動粘貼一個user-agent就行了
不用fake_useragent,打包成exe是 14M,已經不錯了,先交差再說
之后經過了多次探索,多次放棄的邊緣(反復刪除創建環境),終於找到了完美打包的方法
結論
關鍵點就一個:要在虛擬環境里安裝pyinstaller
如果你沒有在虛擬環境中安裝pyinstaller,你同樣可以使用pyinstaller命令,但是調用的是你系統原本的那個python編譯器,內含很多關聯庫,導致即使在虛擬環境中,你打包的exe文件仍然非常大。
另外一點要注意的是:要在虛擬環境里安裝好你py文件中調用的庫,不然打包出來也沒法正常運行。
最后再復習一下正確流程 (前提是安裝好pipenv):