当我使用this网址为Vincent van Gogh的作品列表维基百科页面调用JSON文件时, 它显然会返回一大块文本,我相信它是某种列表字典。
现在,有人已经向我展示了Python的导入维基百科功能,所以跳过它。我该如何解码这个JSON?我觉得我已经尝试过Python 3的库中的所有内容,并且总是会出现错误,例如,如果我尝试使用此代码,我会得到错误:
data = urllib.request.urlopen(long_json_url)
stuff = json.load(data) #or json.loads(data)
print(stuff)
它返回
TypeError: the JSON object must be str, not 'bytes'
或者如果我尝试这段代码:
data = urllib.request.urlopen(longurl)
json_string = data.read().decode('utf-8')
json_data = json.loads(json_string)
print(json_data)
它不会返回错误,但只是看起来什么都没有
>>>
>>>
但是如果我突出显示那个空白区域并粘贴它,它会粘贴相同的文本块。
{'warnings': {'main': {'*': "Unrecognized parameter: 'Page'"}}, 'query': {'normalized': [{'from': 'list of works by Vincent van Gogh',
...等
如果我尝试for循环:
for entry in json_data:
print(entry)
返回
>>>
query
warnings
>>>
就是这样。所以它没有在那里返回错误,但没有其他更多,只有两个值?您如何将JSON数据转换为可行的Python字典或列表?或者至少,我可以实际阅读更直观的格式?
答案 0 :(得分:2)
如何将JSON数据转换为可行的Python字典或列表?
你已经用
做了json_data = json.loads(json_string)
然而:
for entry in json_data:
print(entry)
只会打印您词典的keys
。如果要打印值,则需要使用:
for entry in json_data:
print(json_data[entry])
如果您检查数据,您会发现主词典有两个keys
。你通过迭代dict获得的那些:
{u'query': {...}, u'warnings': {...}}