gpt4 book ai didi

Python 和 openpyxl 正在将我的共享工作簿保存为非共享

转载 作者:行者123 更新时间:2023-12-01 07:27:49 24 4
gpt4 key购买 nike

使用Python和openpyxl,我有一个代码可以进入工作簿,每天向一些单元格添加一堆信息,然后关闭并保存它。我的问题是,如果打开此工作簿,代码将无法工作(显然)。

通过共享工作簿(多个用户可以同时编辑),我可以克服这个问题,但是在代码运行一次后,python 会保存然后将其恢复为关闭的、非共享的工作簿。有人知道 openpyxl 是否可以保存为共享吗?我在网上找不到任何东西。首先感谢您的帮助。

最佳答案

似乎当openpyxl保存Excel工作簿时,里面的docProps/app.xml文件被删除并且只包含很少的信息。

一个快速(但肮脏)的解决方案是使用 zipfile 来获取这些信息并将它们传输到新的/保存的文件中。

import zipfile, openpyxl

def shared_pyxl_save(file_path, workbook):
"""
`file_path`: path to the shared file you want to save
`workbook`: the object returned by openpyxl.load_workbook()
"""
zin = zipfile.ZipFile(file_path, 'r')
buffers = []
for item in zin.infolist():
buffers.append((item, zin.read(item.filename)))
zin.close()

workbook.save(file_path)

zout = zipfile.ZipFile(file_path, 'w')
for item, buffer in buffers:
zout.writestr(item, buffer)
zout.close()

关于Python 和 openpyxl 正在将我的共享工作簿保存为非共享,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57363072/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com