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, 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版本不一致等)。

  • 4
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值