Python读取csv注释

Python的pandas库处理csv文件非常方便,开发过程中经常会用到csv文件,例如将csv中的数据转化为二进制、将csv文件转化为json等。由于csv本身是以列表的形式组织数据的,如果想要额外的加入一些描述信息,比如版本号等,应该如何做呢?

可以以key-value的形式在csv文件头部写入一些信息

#Version:v1.0
#Data:2021/01/01
#Author:Jam
#Description: This is a example of csv commit

利用以下函数可以从csv文件中以字典的形式获取注释中的key-value

def csv_read_attrs(filename):
    s = ''
    fobj = open(filename)
    while True:
        line = fobj.readline()
        if not line:
            break
        s += line
    attrs = re.findall(r'#(.*)', s)
    keys = [x.split(':')[0].strip() for x in attrs]
    values = [x.split(':')[1].strip() for x in attrs]
    attrs = dict(zip(keys,values))
    return attrs

将上述注释保存为test.csv文件,调用csv_read_attrs函数解析注释信息

>>> import csv_read_attrs from csvAttrs
>>> attrs = csv_read_attrs('test.csv')
>>> attrs
{'Version': 'v1.0', 'Data': '2021/01/01', 'Author': 'Jam', 'Description': 'This is a example of csv commit'}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Wei.Studio

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值