簡體   English   中英

帶有 Python 的 PyInstaller:3.10.0b4 - ImportError:沒有名為 _bootlocale 的模塊

[英]PyInstaller with Python: 3.10.0b4 - ImportError: No module named _bootlocale

我安裝了 Python 10 的 Beta 4(我必須使用它,因為我需要僅在 v3.10 中提供的模式匹配功能):

C:\Users\myname\Documents\Projects\Project Migration\SeleniumExamplePy>py -3 --version
Python 3.10.0b4

我確保我的 pyinstaller 是最新的:

    C:\Users\myname\Documents\Projects\Project Migration\SeleniumExamplePy>pip install --upgrade pyinstaller
Requirement already satisfied: pyinstaller in c:\users\myname\appdata\local\programs\python\python310\lib\site-packages (4.4)
Requirement already satisfied: pefile>=2017.8.1 in c:\users\myname\appdata\local\programs\python\python310\lib\site-packages (from pyinstaller) (2021.5.24)
Requirement already satisfied: pyinstaller-hooks-contrib>=2020.6 in c:\users\myname\appdata\local\programs\python\python310\lib\site-packages (from pyinstaller) (2021.2)
Requirement already satisfied: pywin32-ctypes>=0.2.0 in c:\users\myname\appdata\local\programs\python\python310\lib\site-packages (from pyinstaller) (0.2.0)
Requirement already satisfied: setuptools in c:\users\myname\appdata\local\programs\python\python310\lib\site-packages (from pyinstaller) (56.0.0)
Requirement already satisfied: altgraph in c:\users\myname\appdata\local\programs\python\python310\lib\site-packages (from pyinstaller) (0.17)
Requirement already satisfied: future in c:\users\myname\appdata\local\programs\python\python310\lib\site-packages (from pefile>=2017.8.1->pyinstaller) (0.18.2)

我在嘗試將經過徹底測試的 python 代碼轉換為可執行文件時遇到ImportError: No module named _bootlocale錯誤:

**C:\Users\myname\Documents\Projects\Project Migration\SeleniumExamplePy>pyinstaller --onefile --clean ExtractRules.spec**
83 INFO: PyInstaller: 4.4
83 INFO: Python: 3.10.0b4
100 INFO: Platform: Windows-10-10.0.18363-SP0
110 INFO: UPX is not available.
110 INFO: Removing temporary files and cleaning cache in C:\Users\myname\AppData\Local\pyinstaller
113 INFO: Extending PYTHONPATH with paths
['C:\\Users\\myname\\Documents\\Projects\\Project '
 'Migration\\SeleniumExamplePy',
 'C:\\Users\\myname\\Documents\\Projects\\Project '
 'Migration\\SeleniumExamplePy']
126 INFO: checking Analysis
126 INFO: Building Analysis because Analysis-00.toc is non existent
126 INFO: Initializing module dependency graph...
126 INFO: Caching module graph hooks...
139 INFO: Analyzing base_library.zip ...
3449 INFO: Processing pre-find module path hook distutils from 'c:\\users\\myname\\appdata\\local\\programs\\python\\python310\\lib\\site-packages\\PyInstaller\\hooks\\pre_find_module_path\\hook-distutils.py'.
3449 INFO: distutils: retargeting to non-venv dir 'c:\\users\\myname\\appdata\\local\\programs\\python\\python310\\lib'
Traceback (most recent call last):
  File "c:\users\myname\appdata\local\programs\python\python310\lib\runpy.py", line 196, in _run_module_as_main
    return _run_code(code, main_globals, None,
  File "c:\users\myname\appdata\local\programs\python\python310\lib\runpy.py", line 86, in _run_code
    exec(code, run_globals)
  File "C:\Users\myname\AppData\Local\Programs\Python\Python310\Scripts\pyinstaller.exe\__main__.py", line 7, in <module>
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\__main__.py", line 126, in run
    run_build(pyi_config, spec_file, **vars(args))
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\__main__.py", line 65, in run_build
    PyInstaller.building.build_main.main(pyi_config, spec_file, **kwargs)
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\building\build_main.py", line 758, in main
    build(specfile, kw.get('distpath'), kw.get('workpath'), kw.get('clean_build'))
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\building\build_main.py", line 705, in build
    exec(code, spec_namespace)
  File "ExtractRules.spec", line 7, in <module>
    a = Analysis(['ExtractRules.py'],
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\building\build_main.py", line 254, in __init__
    self.__postinit__()
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\building\datastruct.py", line 159, in __postinit__
    self.assemble()
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\building\build_main.py", line 354, in assemble
    self.graph = initialize_modgraph(
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\depend\analysis.py", line 882, in initialize_modgraph
    graph = PyiModuleGraph(
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\depend\analysis.py", line 122, in __init__
    self._analyze_base_modules()
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\depend\analysis.py", line 289, in _analyze_base_modules
    self._base_modules = [mod
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\depend\analysis.py", line 291, in <listcomp>
    for mod in self.import_hook(req)]
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\lib\modulegraph\modulegraph.py", line 1505, in import_hook
    target_package, target_module_partname = self._find_head_package(
  File "c:\users\myname\appdata\local\programs\python\python310\lib\site-packages\PyInstaller\lib\modulegraph\modulegraph.py", line 1711, in _find_head_package
    raise ImportError("No module named " + target_package_name)
ImportError: No module named _bootlocale

我查看了這條評論https://bugzilla.redhat.com/show_bug.cgi?id=1899950AzyCrw4282發布了鏈接以回應一個非常相似的問題PyInstaller - ImportError: No module named _bootlocale並且Victor有一個聲明斯廷納 2021-01-19 10:25:32 UTC

“哦,_bootlocale 是一個私有模塊,不應直接導入。我將其刪除並用 Python 3.10 中的新 _locale._get_locale_encoding() function 替換它”

那么,如果模塊被刪除,為什么最新的 pyinstaller 仍然試圖將其拉入? 是因為我使用的是 Python 3.10b4 並且 pyinstaller 還沒有更新嗎? 有沒有辦法從可執行文件構建中排除 _bootlocale 模塊以便能夠構建可執行文件?

我對我的程序進行了詳盡的測試,從.py 運行時它沒有問題。 我不會調用任何直接引用 bootlocale 模塊的東西,也不是 100% 確定它在從 3.10 中刪除之前做了什么或做了什么。

這是一個 Python 3.10 兼容性問題,這里提到了

您可以通過在命令中添加--exclude-module _bootlocale來解決它。

例如:

pyinstaller.exe app.py --exclude-module _bootlocale

有同樣的問題,你只需要安裝 pyinstaller 然后安裝 3.10 支持。

利用:

pip install pyinstaller
pip install https://github.com/rokm/pyinstaller/archive/refs/heads/python-3.10.zip

嘗試安裝最新版本的 Pyinstaller
這解決了我的問題:

pip install pyinstaller==4.10

將 --exclude-module _bootlocale 添加到命令行為我解決。 非常感謝@LingYan Meng

使用此命令首先安裝pyinstaller

pip install pyinstaller==4.10

或者,如果您想安裝最新版本的pyinstaller ,請使用:

pip install pyinstaller

安裝后嘗試再次創建您的exe,它將起作用。

這似乎是 pyinstaller 和 python 之間的版本不匹配。 我最近升級到 python3.10,從 requirements.txt 安裝,然后遇到了這個問題。 我正在運行 pyinstaller 4.5.1,但最新的是 pyinstaller 5.1。 您可以通過執行以下操作獲取最新的 pyinstaller:

pip install --upgrade pyinstaller

或者

python -m pip install --upgrade pyinstaller

在我的情況下,我通過卸載 fbs 包解決了它

pip3 uninstall fbs

我通過編輯 pyproject.toml 在我的詩歌項目中修復了它:

[tool.poetry.dependencies]
python = "^3.8"

[tool.poetry.dependencies]
python = "^3.8,<3.11"

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM