使用JSON的Python CSV模块问题

时间:2013-09-27 03:59:15

标签: python json csv

我使用python csv模块创建一个csv,其中一些值是json个字符串。但是csv模块的引用完全破坏了json:

import csv
import json
writer = csv.writer(open('tmp', 'w'))
writer.writerow([json.dumps([{'a' : 'b'}])])

输出的json坏了,你可以看到:

cat tmp
> "[{""a"": ""b""}]"

import json
json.loads("[{""a"": ""b""}]")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/lib/python2.7/json/__init__.py", line 326, in loads
    return _default_decoder.decode(s)
  File "/usr/lib/python2.7/json/decoder.py", line 366, in decode
    obj, end = self.raw_decode(s, idx=_w(s, 0).end())
  File "/usr/lib/python2.7/json/decoder.py", line 382, in raw_decode
    obj, end = self.scan_once(s, idx)
ValueError: Expecting property name: line 1 column 2 (char 2)

csv反对引用引用:

import csv
import json
writer = csv.writer(open('tmp', 'w'), quoting=csv.QUOTE_NONE)
writer.writerow([json.dumps([{u'a' : u'b'}])])
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
_csv.Error: need to escape, but no escapechar set

还有其他人遇到过这个吗? jsoncsv只是不能很好地融合在一起吗? (我的想法不是将json搅拌存储在csv文件中......我现在需要处理的事情。不幸的是,我正在创建的这些csv包含散列摘要和各种其他复杂的东西,因此所有sedawk类型解决方案来修复我尝试过的json失败或搞砸了别的东西。

1 个答案:

答案 0 :(得分:2)

不要使用"作为引号字符。使用别的东西:

with open('tmp', 'w') as fout:
    writer = csv.writer(fout, quotechar="'")

真的,这只是整齐的东西。当您重新读取数据时,首先需要通过csv.reader读取数据来“取消引用”它。这应该会给你回放你输入的有效json字符串。