**
使用python 3.7,openpyxl模块处理list时出现数据丢失
**
之前发过一篇文章,现在这一篇是接着上一篇
使用openpyxl模块时,数据丢失问题已经解决了,
之前数据丢失是因为使用的方法错了,
以下为正确的使用方法,
正确代码如下:
#usr/bin/ env python
from openpyxl import Workbook #创建工作簿
wb = Workbook()
ws = wb.create_sheet("sheet") #ws = worksheet,创建名字为sheet1的工作表
ws = wb.active
array = [
['p', 'y', 't', 'h', 'o', 'n'], #list1
['我', '爱', '吃', '肉'], #list2
[1, 2, 3, 4, 5, 6, 7] #list3
]
for i in range(len(array)):
j=0
for item in array[i]:
j+=1
ws.cell(row=i+1, column=j, value=item)
wb.save('1.xlsx')
之前会数据丢失和报错,是因为循环方法用错了。
下面代码中的第二个"for"中,我将长度定死了,所以才会出现数据丢失,
cols = len(array[0])
这句中cols的范围是 “list1” 的长度,是定死的,只要其他 “list” 长度不同于 “list1”,就会出现问题,
只要将循环范围改为变量 “i” 即可。
for item in array[i]:
以上,也许还有更简单方便的方法,至此记录。
2020-5-24 17:56