Abh*_*ath 23 python csv python-2.7
我有一个CSV文件,其中包含以下行:
"AAA", "BBB", "Test, Test", "CCC"
"111", "222, 333", "XXX", "YYY, ZZZ"
Run Code Online (Sandbox Code Playgroud)
等等 ...
我不想用双引号解析逗号.即.我的预期结果应该是
AAA
BBB
Test, Test
CCC
Run Code Online (Sandbox Code Playgroud)
我的代码:
import csv
with open('values.csv', 'rb') as f:
reader = csv.reader(f)
for row in reader:
print row
Run Code Online (Sandbox Code Playgroud)
我尝试在python下使用csv包但没有运气.解析会爆炸所有逗号.
如果我遗失了什么,请告诉我
Mic*_*ael 43
这应该做:
lines = '''"AAA", "BBB", "Test, Test", "CCC"
"111", "222, 333", "XXX", "YYY, ZZZ"'''.splitlines()
for l in csv.reader(lines, quotechar='"', delimiter=',',
quoting=csv.QUOTE_ALL, skipinitialspace=True):
print l
>>> ['AAA', 'BBB', 'Test, Test', 'CCC']
>>> ['111', '222, 333', 'XXX', 'YYY, ZZZ']
Run Code Online (Sandbox Code Playgroud)
Mar*_*ers 12
输入中的引号字符前面有空格.设置skipinitialspace为True跳过分隔符后面的任何空格:
何时
True,忽略分隔符后面的空格.默认是False.
>>> import csv
>>> lines = '''\
... "AAA", "BBB", "Test, Test", "CCC"
... "111", "222, 333", "XXX", "YYY, ZZZ"
... '''
>>> reader = csv.reader(lines.splitlines())
>>> next(reader)
['AAA', ' "BBB"', ' "Test', ' Test"', ' "CCC"']
>>> reader = csv.reader(lines.splitlines(), skipinitialspace=True)
>>> next(reader)
['AAA', 'BBB', 'Test, Test', 'CCC']
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
44700 次 |
| 最近记录: |