我有一个像
这样的地址line = 12345 North Drive,,"Palm Retreat, CO",CO,92261
当我分手时,我得到了
line.split(",")
['12345 North Drive', '', '"Palm Retreat', ' CO"', 'CO', '92261']
我想要的只是
'12345 North Drive', '', '"Palm Retreat CO"', 'CO', '92261']
我在这里失踪的是什么?
答案 0 :(得分:4)
split()
按预期工作;它不关心报价。您可能需要查看csv
模块以及StringIO
:您将字符串放在StringIO
对象中(使其看起来像文件)然后传递给它到csv.reader
。像这样:
import csv
from cStringIO import StringIO
s = "12345 North Drive,,\"Palm Retreat, CO\",CO,92261"
s = StringIO(s)
reader = csv.reader(s, delimiter=",")
for row in reader:
print row
更新:实际上,由于csv.reader
适用于任何产生行(而不仅仅是文件)的迭代,因此您只需将行列表传递给csv.reader
而无需经过StringIO
位。
答案 1 :(得分:0)
您应该使用csv
模块来处理CSV数据。