问题描述
我有一个脚本,旨在通过多处理管理器将 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 (将#修改为@)