我有一个df.to_excel()
我正在努力解决的简单用例。我想写入现有 XLSX 工作簿的特定工作表选项卡(我们称之为“数据”),它可以被其他选项卡上的公式和数据透视表引用。
我尝试以两种方式修改 ExcelWriter,但都从 openpyxl 产生错误。
- 使用 get_sheet_by_name 读取现有工作表(此错误:“NotImplementedError: use 'iter_rows()' instead”。)
使用 create_sheet 创建一个新工作表。(此错误:“ReadOnlyWorkbookException:无法在只读工作簿中创建新工作表”)
df=DataFrame() from openpyxl.reader.excel import load_workbook book = load_workbook('my_excel_file.xlsx', use_iterators=True) # Assume my_excel_file.xlsx contains a sheet called 'Data' class temp_excel_writer(ExcelWriter): # I need this to inherit the other methods of ExcelWriter in io/parsers.py def __init__(self, path, book): self.book=book test_sheet=self.book.create_sheet(title='Test') # This errors: ReadOnlyWorkbookException self.use_xlsx = True self.sheet_names=self.book.get_sheet_names() self.actual_sheets=self.book.worksheets self.sheets={} for i,j in enumerate(self.sheet_names): self.sheets[j] = (self.actual_sheets[i],1) self.cur_sheet = None self.path = save my_temp_writer=temp_excel_writer('my_excel_file.xlsx', book) df.to_excel(my_temp_writer, sheet_name='Data')
有什么想法吗?我错过了一些明显的东西吗?我还在熊猫 7.2