如何避免 Excel 写入数据覆盖问题并准确获取写入行数和列数?
如何准确获取写入 excel 时的行数和列数
在将数据写入 excel 时,代码有时候会出现后一次写入的数据覆盖了前一次写入的数据的情况。对于这种情况,可以借助辅助工具来解决。
代码片段中关键问题是,在 for 循环中,向单元格写入数据并覆盖了前一次写入的数据。要解决此问题,可以使用 xlwt 库提供的 workbook 实例的 save 方法。该方法会在每次写入数据后保存文件。
在示例代码中,可以将第 12 行的 book.save 方法移到 for 循环外部,如下所示:
import xlwtbook = xlwt.Workbook(encoding='utf-8', style_compression=0) # 创建文件sheet = book.add_sheet('sheet1', cell_overwrite_ok=True) # 指定sheet表名称h = 1 # 行号for con in cons: l = 0 # 列号 for num in range(0, 13): sheet.write(h, l, con[num]) l += 1 # 列要加一 h += 1 # 一个数据写完之后,要换行了,行号加一 book.save('%s.xls' % str(con[0] + '(' + con[1] + ')')) # 保存文件
现在,每次写入一条数据后,都会保存 excel 文件。这样,就不会出现覆盖之前写入的数据的情况。
通过这种方法,可以准确获取写入 excel 时的行数和列数。