关于python3的不同长度数组的输出_2

**

使用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

你可能感兴趣的:(python)