用pyinstaller打包带有openpyxl模块的项目时,打包完成后,运行程序出现报错,
ModuleNotFoundError: No module named openpyxl.cell.writer'
其本质是,pyinstaller打包的时候,通常可以自动检测到项目所使用的依赖项并将其包含在打包的可执行文件中。但是,有些情况下,PyInstaller可能会无法自动检测到某些依赖项,这时就需要使用–hidden-import选项显式地将它们包含进去。
因此,在使用Pyinstaller打包项目时,使用–hidden-import选项,告诉PyInstaller需要包含哪些依赖项的方法。
在运行PyInstaller时,你应该根据你的代码中需要的依赖项使用–hidden-import选项,以确保所有依赖项都被正确地包含在生成的可执行文件中。
所以,使用一下的打包命令可以解决该问题。
pyinstaller -F main.py -n [程序名称] --hidden-import=openpyxl
By the way, 看到有些博客说,检索到pyinstaller的hook-openpyxl.py文件内容如下,
# ------------------------------------------------------------------
# Copyright (c) 2020 PyInstaller Development Team.
#
# This file is distributed under the terms of the GNU General Public
# License (version 2.0 or later).
#
# The full license is available in LICENSE.GPL.txt, distributed with
# this software.
#
# SPDX-License-Identifier: GPL-2.0-or-later
# ------------------------------------------------------------------
# Hook for the openpyxl module: https://pypi.python.org/pypi/openpyxl
# Tested with openpyxl 2.3.4, Python 2.7, Windows
from PyInstaller.utils.hooks import collect_data_files
datas = collect_data_files('openpyxl')
说pyinstaller仅支持openpyxl 2.3.4,该论断并不合理,有文件内容可知,该版本使用openpyxl 2.3.4、Python 2.7、Windows进行测试,而非仅支持,特此纠正。
当然,如果你的项目中只包含openpyxl库,而不涉及其他调用openpyxl的库文件(如,pandas),则可以简单的将目前项目中所使用的openpyxl进行降级,以便捷的使用pyinstaller进行打包,当然你需要警惕库文件降级带来的某些函数功能的变化。
如果你在项目中同时使用了pandas等库文件,需要依赖于openpyxl时 ,如果简单的按照上述方法进行降级操作,则你会遇到新的错误(即pandas版本与openpyxl版本不一致等)。