csv在python中的意思_在Python中从内存中解析CSV数据

这就是为什么你应该使用cStringIO.StringIO(Python 3.x中的io.StringIO)而不是一些DIY kludge:

>>> import csv

>>> from cStringIO import StringIO

>>> fromDB = '"Column\nheading1",hdng2\r\n"data1\rfoo","data2\r\nfoo"\r\n'

>>> sources = [StringIO(fromDB), fromDB.splitlines(True),

... fromDB.splitlines(), fromDB.split("\n")]

>>> for i, source in enumerate(sources):

... print i, list(csv.reader(source))

...

0 [['Column\nheading1', 'hdng2'], ['data1\rfoo', 'data2\r\nfoo']] # OK

1 [['Column\nheading1', 'hdng2'], ['data1\rfoo', 'data2\r\nfoo']] # OK

2 [['Columnheading1', 'hdng2'], ['data1foo', 'data2foo']] # 3 errors

3 [['Columnheading1', 'hdng2'], ['data1\rfoo', 'data2\rfoo'], []] # 3 errors

>>>建议不要使用guff.splitlines(True),因为它比StringIO(guff)有更大的机会,无论谁在阅读你的代码,都不知道它的作用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值