如何将txt格式文件逐行读取转为excel文件

研发给的txt文件数据量超级大,看着费劲。于是自己动手写了个脚本转为excel表格,脚本亲测很好用,分享出来。txt内容格式如下,每行看起来跟python的字典很像。

{k1:v1,k2:v2,......}

{k1,x1,k2:x2,......}

 

import codecs,pandas as pd
###定义文件路径,如果与脚本在同一目录,直接定义文件名
filename = "test.txt"
###打开文件
f = codecs.open(filename, encoding='UTF-8-sig')
col = []
rows = []
l = 0
###逐行读取txt
for line in f.readlines():
    ###每行内容,由str转为dict
    line = eval(line)
    row = []
    l += 1
    ###取出dict中的value值,作为每行的列值
    for v in line.values():
        row.append(v)
    if l == 1:
        ###取出dict中的key,作为列头;每行的key都是完全一样的,只取一次即可
        for k in line.keys():
            col.append(k)
        print("列获取成功%s"%col)
    rows.append(row)
    print("第%s歌"%l)
print("读取数据成功,开始转为excel")
###保存到excel表格
df = pd.DataFrame(rows, columns=col)
w = pd.ExcelWriter("test.xls")
df.to_excel(w, sheet_name='vip', index=False)
w.save()
w.close()
print("转换成功")

 

 

 

 

你可能感兴趣的:(python编程)