gpt4 book ai didi

Python CSV 模块与 JSON 的问题

转载 作者:行者123 更新时间:2023-12-01 05:36:03 33 4
gpt4 key购买 nike

我正在使用 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 不能很好地协同工作吗? (将 jsonstirngs 存储在 csv 文件中不是我的想法……我现在只需要处理的东西)。不幸的是,我创建的这些 csv 包含哈希摘要和各种其他复杂的内容,因此我尝试过的所有用于修复 json 的 sed 或 awk ish 类型解决方案都失败了或者弄乱了其他东西..

最佳答案

不要使用 " 作为引号字符。使用其他字符:

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

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

关于Python CSV 模块与 JSON 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19042460/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com