微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用多处理管理器加载 openpyxl 时出错

如何解决使用多处理管理器加载 openpyxl 时出错

我有一个脚本,旨在通过多处理管理器将 excel 工作簿(通过 openpyxl)传递给多个工作人员。

似乎 openpyxl 对象在多处理管理器中没有正确表示,并且对象重新实例化不正确,给出以下错误消息: TypeError: __init__() missing 1 required positional argument: 'worksheet'

这是一个 MWE:

import multiprocessing
import openpyxl

excelfile = r"path-to-excel.xlsx"

workbook = openpyxl.load_workbook(excelfile)

print(workbook.sheetnames)

if __name__ == "__main__":
    with multiprocessing.Manager() as mananger:
        run_dictionary = mananger.dict()
        run_dictionary['workbook'] = workbook

        print(run_dictionary['workbook'].sheetnames)

as manager 环境之外操作时,读取对象属性工作正常,但在该环境内执行时,会引发 Error

我已经看到 here openpyxl 和多处理可能存在一些问题,但就我而言,我只是在阅读 excel。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。