学python最重要的是练习,学了不练假把式。每天找点有意思的练习题做做,强化python技能很有裨益。
需求:现有list.txt文件存放了商品销售数据,需要读取该文件到字典列表。
文件内容:
商品,单价,数量
苹果,4.8,5
雪梨,2.9,10
大枣,5.8,6
预期结果是:
[{'商品': '苹果', '单价': '4.8', '数量': '5'},
{'商品': '雪梨', '单价': '2.9', '数量': '10'},
{'商品': '大枣', '单价': '5.8', '数量': '6'}]
先做分析:文件是文本文件,uf8编码,用open默认r模式打开即可。第一行内容判断为字典的key,后面的行是value。
with open('a.txt', encoding='utf8') as f:
name = f.readline().strip().split(',') # 读取文件第一行转成list,作为字典的key
fruit_list = []
for line in f: # 用for循环遍历句柄f,优点是无论文件有多大,读取都不会撑爆内存。
# 不要用read()或readlines(),万一处理的文件超大会导致撑爆内存。
if len(line) < 3: # 过滤空行及数据不完整的行。