我正在努力使用xlutils并复制工作表。下面的代码成功地复制了第一个工作表并添加了两个副本,但是,当我写入每个工作表时,它会将更改应用于所有工作表副本以及原始副本。
因此,在下面的示例中,所有3个工作表的第3行、第0/1列的值都是"test2“。
有人知道我哪里做错了吗?我还尝试添加每个克隆,然后尝试workbook.get_sheet(id).write(x,x,x),结果发生了完全相同的事情。
workbook = xlutils.copy.copy(xlrd.open_workbook(xls_out, formatting_info=True))
tmp_workbook = copy(workbook)
copied_sheet = copy(tmp_workbook.get_sheet(0))
copied_sheet.set_name("tmpsheet")
copied_sheet.write(3, 0, 'test1')
copied_sheet.write(3, 1, 'test1')
workbook._Workbook__worksheets.append(copied_sheet)
copied_sheet = copy(tmp_workbook.get_sheet(0))
copied_sheet.set_name("tmpsheet2")
copied_sheet.write(3, 0, 'test2')
copied_sheet.write(3, 1, 'test2')
workbook._Workbook__worksheets.append(copied_sheet)
workbook.save(xls_out)发布于 2014-03-05 21:37:27
利用深度拷贝。复制插入对在原始文件中找到的对象的引用,深度复制将构造一个新的复合,然后将在原始文件中找到的对象的副本插入其中。
https://stackoverflow.com/questions/18624352
复制相似问题