L1 = []
L2 = []
f = open('D:\\学习\\Python\\各章实验内容答案与素材参考\\ch5\\文本文件\\data4.txt', 'r')
while True:
line = f.readline()
if len(line) == 0:
break
else:
L1.append(line.split())
print(L1)
print('*****************************')
for i in L1:
for a in i:
L2.append(a.split(','))
print(L2)
print('*****************************')
for j in L2:
for b in range(3, len(j) - 1 + 1):
j[b] = int(j[b])
print(L2)
如果用普通方法读取结构,应该是这样的。在红色的地方卡了好久,py报错说列表不能split,刚开始不理解,后来发现,i in L1是列表,而不是字符串。
[['黄晓明,东川路156弄3号504室,0000359222,772,789,806,847,880,901,950,991,1022,1043,1064,1089,1114'], ['李红,东川路156弄3号101室,0000359201,121,132,145,156,168,179,192,206,219,230,246,258,273'], ['钱多多,东川路156弄3号102室,0000359202,1008,1046,1102,1167,1209,1255,1311,1362,1407,1453,1512,1563,1604'], ['赵志荣,东川路156弄3号103室,0000359203,541,567,590,622,651,689,701,732,758,775,796,814,847'], ['秦天君,东川路156弄3号104室,0000359204,401,412,441,466,479,490,508,522,541,572,603,637,666']]
书上的答案没有二层for是因为,用list()语句得到的列表里面没有嵌套,实际上还要用语句把它变成嵌套的。但是变嵌套和字符串逗号分开是在一行里完成的,所以看起来比较简洁。
L1 = list(open('D:\\学习\\Python\\各章实验内容答案与素材参考\\ch5\\文本文件\\data4.txt','r'))
print(L1)
print('***********')
L2 = []
for a in L1:
L2.append(a.split(','))
print(L2)
print('***********')
for b in L2:
for i in range(3,len(b)):
b[i] = int(b[i])
print(L2)