工作正常的 JSON 响应:
obj = urllib.urlopen("http://www.omdbapi.com/?t=Fight Club")
response_str = obj.read()
response_json = simplejson.loads(response_str)
上面的代码发出类似如下的json请求:
{
"Title":"Fight Club",
"Year":"1999",
"Rated":"R",
"Released":"15 Oct 1999",
......
"Response":"True"
}
所以我现在可以睡觉了...但
工作不正常的json响应:
obj = urllib.urlopen("https://api.stackexchange.com/2.1/answers?order=desc&sort=activity&site=stackoverflow")
response_str = obj.read()
response_json = simplejson.loads(response_str)
上面的代码发出类似如下的json请求:
{
"items": [
{
"question_id": 18384375,
"answer_id": 18388044,
"creation_date": 1377195687,
"last_activity_date": 1377195687,
"score": 0,
"is_accepted": false,
"owner": {
"user_id": 1745001,
"display_name": "Ed Morton",
"reputation": 10453,
"user_type": "registered",
"profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=128&d=identicon&r=PG",
"link": "https://stackoverflow.com/users/1745001/ed-morton"
}
},
{
"question_id": 18387447,
"answer_id": 18388040,
"creation_date": 1377195667,
"last_activity_date": 1377195667,
"score": 0,
"is_accepted": false,
"owner": {
"user_id": 2494429,
"display_name": "kpark91",
"reputation": 140,
"user_type": "registered",
"profile_image": "https://www.gravatar.com/avatar/d903a03e7c5b6d9b21ff598c632de575?s=128&d=identicon&r=PG",
"link": "https://stackoverflow.com/users/2494429/kpark91"
}
}
]
}
退货
JSONDecodeError at /
No JSON object could be decoded: line 1 column 0 (char 0)
我没有使用SimpleJson,而是尝试了json,它给出了以下错误:
ValueError at /
No JSON object could be decoded
我尝试过但失败了:
我尝试了我的问题的答案 堆栈溢出 遇到同样的问题,但没有一个给出明确的解决方案,尽管每个人都以某种方式帮助了我
1) 我检查了json内容编码是否正确
>>obj.info()
Content-Type: application/json;
charset=utf-8
Content-Length: 2398
2)我用UTF-8解码了response_str
json.loads(response_str).decode("utf-8")
3)我使用jsonlint来检查json响应的格式
Parse error on line 1:
^
Expecting '{', '['
令人惊讶的是下面的链接拯救了我的睡眠。JSONDecodeError:预期值:第1行第1列(char 0)
基本上,我在这两种情况下都使用精确的代码来获取 json 响应,但是第二个 json 响应有什么问题,唯一的区别是我注意到第二个 json 响应的结构与第一个不同。
请提供解释以理解问题。
让我给你一些建议。使用< code>urllib很好,但是你会遇到很多麻烦。所以,让我帮你省点力气,直接带你去< code>requests。这是处理url请求的最好方法。
这个简短的空闲会话将演示:
>>> r = requests.get('https://api.github.com/user', auth=('user', 'pass'))
>>> r.status_code
200
>>> r.headers['content-type']
'application/json; charset=utf8'
>>> r.encoding
'utf-8'
>>> r.text
u'{"type":"User"...'
>>> r.json()
{u'private_gists': 419, u'total_private_repos': 77, ...}
要安装它,只需转到命令提示符并 pip 安装要求
。Requets是免费和开源的,它是用纯Python编写的,所以安装很简单。
睡个好觉的一种方法是使用请求:
import requests
import simplejson
response = requests.get("https://api.stackexchange.com/2.1/answers?order=desc&sort=activity&site=stackoverflow")
response_json = simplejson.loads(response.text)
print response_json
没有错误,只是有效。
其他答案提到了请求
库,但基于StackOverflow上的其他一些答案,似乎您也可以修改代码以包含GZip解压缩。基于这个答案,我认为这将是:
import StringIO, gzip
obj = urllib.urlopen("https://api.stackexchange.com/2.1/answersorder=desc&sort=activity&site=stackoverflow")
data = StringIO.StringIO(obj.read())
gzipper = gzip.GzipFile(fileobj=data)
response_json = simplejson.loads(gzipper.read())