当我为Vincent van Gogh的作品列表维基百科页面调用
JSON文件时,使用
this url,
它显然会返回一大块文本,我相信它是某种列表字典.
现在,有人已经向我展示了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’:{‘*’:“无法识别的参数:’Page’”}},’query’:{‘normalized’:[{‘from’:’Vincent van Gogh的作品列表’ ,等等
如果我尝试for循环:
for entry in json_data:
print(entry)
它回来了
>>>
query
warnings
>>>
就是这样.所以它不是在那里返回一个错误,而是在其他方面没有,只有两个值?您如何将JSON数据转换为可行的Python字典或列表?或者至少,我可以实际阅读更直观的格式?
最佳答案
How would you make the JSON data into a workable Python dict or list?
你已经这样做了
json_data = json.loads(json_string)
但是这样:
for entry in json_data:
print(entry)
只会打印字典的键.如果要打印值,则需要使用:
for entry in json_data:
print(json_data[entry])
如果你检查数据,你会发现主词典有两个键.你通过遍历dict获得的那些:
{u'query': {...}, u'warnings': {...}}