1

我正在使用 pythoncsv模块创建一个 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。我现在只需要处理)。不幸的是,我正在创建的这些 csvs 包含哈希摘要和各种其他复杂的东西,所以我尝试过的修复 json 的所有sed或ish 类型的解决方案都失败或搞砸了其他东西。awk

4

1 回答 1

2

不要"用作您的引号字符。使用其他东西:

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

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

于 2013-09-27T04:06:56.960 回答