pyinstaller打包openpyxl和pandas包,报错ModuleNotFoundError openpyxl
用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, Windowsfrom PyInstaller.utils.hooks import collect_data_filesdatas = 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版本不一致等)。
来源地址:https://blog.csdn.net/weixin_44475303/article/details/130587920
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341