gpt4 book ai didi

python - 从文本文件中检索 JSON 对象(使用 Python)

转载 作者:IT老高 更新时间:2023-10-28 20:51:52 24 4
gpt4 key购买 nike

我有数千个包含多个 JSON 对象的文本文件,但不幸的是,这些对象之间没有分隔符。对象存储为字典,它们的一些字段本身就是对象。每个对象可能具有可变数量的嵌套对象。具体来说,一个对象可能如下所示:

{field1: {}, field2: "some value", field3: {}, ...} 

并且数百个这样的对象在文本文件中连接在一起,没有分隔符。这意味着我既不能使用 json.load() 也不能使用 json.loads()

关于如何解决这个问题的任何建议。是否有已知的解析器来执行此操作?

最佳答案

这会从字符串中解码您的 JSON 对象“列表”:

from json import JSONDecoder

def loads_invalid_obj_list(s):
decoder = JSONDecoder()
s_len = len(s)

objs = []
end = 0
while end != s_len:
obj, end = decoder.raw_decode(s, idx=end)
objs.append(obj)

return objs

这里的好处是你可以很好地使用解析器。因此,它会一直告诉您确切在哪里发现了错误。

示例

>>> loads_invalid_obj_list('{}{}')
[{}, {}]

>>> loads_invalid_obj_list('{}{\n}{')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "decode.py", line 9, in loads_invalid_obj_list
obj, end = decoder.raw_decode(s, idx=end)
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 376, in raw_decode
obj, end = self.scan_once(s, idx)
ValueError: Expecting object: line 2 column 2 (char 5)

清洁溶液(稍后添加)

import json
import re

#shameless copy paste from json/decoder.py
FLAGS = re.VERBOSE | re.MULTILINE | re.DOTALL
WHITESPACE = re.compile(r'[ \t\n\r]*', FLAGS)

class ConcatJSONDecoder(json.JSONDecoder):
def decode(self, s, _w=WHITESPACE.match):
s_len = len(s)

objs = []
end = 0
while end != s_len:
obj, end = self.raw_decode(s, idx=_w(s, end).end())
end = _w(s, end).end()
objs.append(obj)
return objs

示例

>>> print json.loads('{}', cls=ConcatJSONDecoder)
[{}]

>>> print json.load(open('file'), cls=ConcatJSONDecoder)
[{}]

>>> print json.loads('{}{} {', cls=ConcatJSONDecoder)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/__init__.py", line 339, in loads
return cls(encoding=encoding, **kw).decode(s)
File "decode.py", line 15, in decode
obj, end = self.raw_decode(s, idx=_w(s, end).end())
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 376, in raw_decode
obj, end = self.scan_once(s, idx)
ValueError: Expecting object: line 1 column 5 (char 5)

关于python - 从文本文件中检索 JSON 对象(使用 Python),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8730119/

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