【发布时间】:2013-05-10 12:20:01
【问题描述】:
我在尝试解码 JSON 时收到错误 Expecting value: line 1 column 1 (char 0)。
我用于 API 调用的 URL 在浏览器中运行良好,但在通过 curl 请求完成时会出现此错误。以下是我用于 curl 请求的代码。
错误发生在return simplejson.loads(response_json)
response_json = self.web_fetch(url)
response_json = response_json.decode('utf-8')
return json.loads(response_json)
def web_fetch(self, url):
buffer = StringIO()
curl = pycurl.Curl()
curl.setopt(curl.URL, url)
curl.setopt(curl.TIMEOUT, self.timeout)
curl.setopt(curl.WRITEFUNCTION, buffer.write)
curl.perform()
curl.close()
response = buffer.getvalue().strip()
return response
追溯:
File "/Users/nab/Desktop/myenv2/lib/python2.7/site-packages/django/core/handlers/base.py" in get_response
111. response = callback(request, *callback_args, **callback_kwargs)
File "/Users/nab/Desktop/pricestore/pricemodels/views.py" in view_category
620. apicall=api.API().search_parts(category_id= str(categoryofpart.api_id), manufacturer = manufacturer, filter = filters, start=(catpage-1)*20, limit=20, sort_by='[["mpn","asc"]]')
File "/Users/nab/Desktop/pricestore/pricemodels/api.py" in search_parts
176. return simplejson.loads(response_json)
File "/Users/nab/Desktop/myenv2/lib/python2.7/site-packages/simplejson/__init__.py" in loads
455. return _default_decoder.decode(s)
File "/Users/nab/Desktop/myenv2/lib/python2.7/site-packages/simplejson/decoder.py" in decode
374. obj, end = self.raw_decode(s)
File "/Users/nab/Desktop/myenv2/lib/python2.7/site-packages/simplejson/decoder.py" in raw_decode
393. return self.scan_once(s, idx=_w(s, idx).end())
Exception Type: JSONDecodeError at /pricemodels/2/dir/
Exception Value: Expecting value: line 1 column 1 (char 0)
【问题讨论】:
-
为什么要解码响应? (
simple)json可以很好地处理 UTF-8 编码的 JSON。 -
最后但同样重要的是,
print repr(response_json)告诉您什么正在传递给.loads()? -
还有一个:当你可以使用标准库
json(与simplejson相同的库)时,为什么还要使用simplejson? -
当我执行
print repr(response_json)时,它只会显示u'' -
那是一个空字符串。您的
web_fetch()呼叫失败。