我有成千上万个包含多个JSON对象的文本文件,但不幸的是,对象之间没有分隔符.对象存储为字典,其中一些字段本身就是对象.每个对象可能具有可变数量的嵌套对象.具体来说,对象可能如下所示:
{field1: {}, field2: "some value", field3: {}, ...}
Run Code Online (Sandbox Code Playgroud)
并且在文本文件中没有分隔符的情况下连接数百个这样的对象.这意味着我既不能使用json.load()也不能json.loads().
关于如何解决这个问题的任何建议.有没有一个已知的解析器来做到这一点?
试图从需要登录的URL解析json.包括我在这里的所有代码,因为我不确定错误在哪里.
try: import simplejson as json
except ImportError: import json
import urllib2
username = 'user'
password = '1234'
url = "https://www.blah.com/someplace"
# set up the username/password/url request
password_mgr = urllib2.HTTPPasswordMgrWithDefaultRealm()
password_mgr.add_password(None, "https://www.blah.com", username, password)
handler = urllib2.HTTPBasicAuthHandler(password_mgr)
opener = urllib2.build_opener(handler)
urllib2.install_opener(opener)
request = urllib2.Request(url)
response = opener.open(request)
# option 1
json_object = json.loads(str(response))
#option 2
json_object = json.loads(response)
Run Code Online (Sandbox Code Playgroud)
如果我使用选项1运行代码(注释掉选项2),我会收到此错误:
Traceback (most recent call last):
File "jsontest.py", line 22, in <module>
json_object = json.loads(str(request))
File "/usr/lib/python2.7/dist-packages/simplejson/__init__.py", line 413, in loads
return …Run Code Online (Sandbox Code Playgroud)