Pyinstaller打包工具


本篇博客主要介紹的是pyinstaller在windows下的基本使用和基礎避坑

在windows中使用pyinstaller工具打包時會出現一個問題,在打包列表會看到這樣的警告信息:

django.core.exceptions.ImproperlyConfigured: Could not find the GDAL library (tried "gdal302", "gdal30
1", "gdal300", "gdal204", "gdal203", "gdal202", "gdal201", "gdal20"). Is GDAL installed? If it is, try
 setting GDAL_LIBRARY_PATH in your settings.
collect_submodules: failed to import 'django.contrib.gis.sitemaps'!

這種信息不予理會就好了。

一、基本使用

1、安裝pyinstall

# pip install pyinstaller

2、查找程序需要的文件

# 制作 .spec 文件
# 進入項目目錄,執行命令:(還有其它參數:-F等, 建議使用-D)
# -D會在當前目錄下的dist目錄中生成文件夾,處理靜態文件時比較方便
# pyi-makespec -D manage.py

3、生成.exe文件

# 在manage.spec 同級目錄執行
# pyinstaller manage.spec

4、進入dist目錄運行項目

# 生成的exe可執行文件 runserver --noreload
# manage.exe runserver --noreload

5、配置運行時瀏覽器自啟動

在配置文件中修改為如下配置即可

"""
WSGI config for bookstore project.

It exposes the WSGI callable as a module-level variable named ``application``.

For more information on this file, see
https://docs.djangoproject.com/en/1.11/howto/deployment/wsgi/
"""

import os
import time
import threading
import webbrowser

from django.core.wsgi import get_wsgi_application


def open_w():
    time.sleep(1)
    webbrowser.open_new_tab('http://127.0.0.1:8100')

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "bookstore.settings")

application = get_wsgi_application()

t1 = threading.Thread(target=open_w)
t1.start()

二、基本錯誤處理

1、當運行exe后出現提示:No module named XXX

出現原因:出現這種情況的原因主要是由於Django有些module不會自動收集,需要手動添加

解決辦法:打開生成的后綴名為.spec的文件,在hiddenimports中添加報錯中沒有的模塊

2、當運行出現報錯:UnicodeDecodeError: 'gbk' codec can't decode byte 0x80 in position 658: illegal multibyte

出現原因:主要是windows系統下gbk編碼的問題

解決辦法:打開報錯信息上面一行提示的錯誤文件並跳轉到提示的錯誤行數上修改with open(),在里面添加:encoding='utf-8' 即可

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "threading.py", line 890, in _bootstrap
  File "threading.py", line 936, in _bootstrap_inner
  File "traceback.py", line 167, in format_exc
  File "traceback.py", line 121, in format_exception
  File "traceback.py", line 521, in __init__
  File "traceback.py", line 533, in _load_lines
  File "traceback.py", line 533, in _load_lines
  File "traceback.py", line 533, in _load_lines
  [Previous line repeated 2 more times]
  File "traceback.py", line 531, in _load_lines
  File "traceback.py", line 285, in line
  File "linecache.py", line 16, in getline
  File "linecache.py", line 47, in getlines
  File "linecache.py", line 103, in updatecache
  File "PyInstaller\loader\pyimod03_importers.py", line 299, in get_source
UnicodeDecodeError: 'gbk' codec can't decode byte 0xa6 in position 11211: illegal multibyte sequence

上面是報錯示例,找到"PyInstaller\loader\pyimod03_importers.py"文件,打開並編譯第299行找到對應位置添加:encoding='utf-8'(注:修改前先備份好備份,以免誤操作找不回)

3、當運行出現這種報錯:TemplateDoesNotExist at /index/

出現原因:TemplateDoesNotExist 這個是因為沒有找到templates文件

解決辦法:根據錯誤提示將templates文件添加至對應的路徑下,刷新即可。

TemplateDoesNotExist at /index/
index/index.html
Request Method:	GET
Request URL:	http://127.0.0.1:8000/index/
Django Version:	3.2.9
Exception Type:	TemplateDoesNotExist
Exception Value:	
index/index.html
Exception Location:	django\template\loader.py, line 19, in get_template
Python Executable:	F:\Workspoace\PyWork\bookstore\dist\manage.exe
Python Version:	3.7.8
Python Path:	
['C:\\Users\\ja\\AppData\\Local\\Temp\\_MEI25882\\base_library.zip',
 'C:\\Users\\ja\\AppData\\Local\\Temp\\_MEI25882\\lib-dynload',
 'C:\\Users\\ja\\AppData\\Local\\Temp\\_MEI25882']
Server time:	Tue, 16 Nov 2021 03:13:35 +0000
Template-loader postmortem
Django tried loading these templates, in this order:

Using engine django:

django.template.loaders.filesystem.Loader: C:\Users\ja\AppData\Local\Temp\_MEI25882\templates\index\index.html (Source does not exist)
django.template.loaders.app_directories.Loader: C:\Users\ja\AppData\Local\Temp\_MEI25882\django\contrib\admin\templates\index\index.html (Source does not exist)
django.template.loaders.app_directories.Loader: C:\Users\ja\AppData\Local\Temp\_MEI25882\django\contrib\auth\templates\index\index.html (Source does not exist)

上面這種示例把template文件夾復制下來放到C:\Users\ja\AppData\Local\Temp_MEI25882\下面即可

4、項目缺少樣式css和js

出現原因:Pyinstaller 能找到templates(html files文件),但不能找到css和js文件

解決辦法:

在settings中配置django靜態文件收集

# STATIC_ROOT = os.path.join(BASE_DIR, '文件夾路徑')

靜態文件收集命令

# python manage.py collectstatic

然后在各個app的url中添加:

# static.static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)

# 這句話的意思就是將STATIC_ROOT目錄的靜態文件復制一份到網頁 STATIC_URL路徑下

在.spec文件中修改datas,配置靜態文件打包:

# F:\Workspoace\PyWork\bookstore\statics 要打包的css,js靜態文件地址 相對應打包到dist中的位置
# F:\Workspoace\PyWork\bookstore\templates 要打包的html文件模板地址 相對應打包到dist中的位置
# datas=[(r'F:\Workspoace\PyWork\bookstore\statics',r'.\statics'), (r'F:\Workspoace\PyWork\bookstore\templates', r'.\templates')],

注:這里配置template打包上面的第3條文件遷移就不需要做了,這里同步打包了。

這里還存在一個小問題就是django的配置文件settings中:

# STATICFILES_DIRS = [
#     os.path.join(BASE_DIR, "statics"),
# ]

STATIC_ROOT = os.path.join(BASE_DIR, 'statics')

STATICFILES_DIRS和STATIC_ROOT不能同時使用,如果配置了STATICFILES_DIRS需要注釋掉,不然會報錯。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM