我得到错误期望值:第1行第1列(字符0)时试图解码JSON。

我用于API调用的URL在浏览器中工作正常,但在通过curl请求完成时给出了这个错误。下面是我用于curl请求的代码。

错误发生在返回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)

当前回答

即使在调用decode()之后,也可能有嵌入的0。使用替代():

import json
struct = {}
try:
    response_json = response_json.decode('utf-8').replace('\0', '')
    struct = json.loads(response_json)
except:
    print('bad json: ', response_json)
return struct

其他回答

我也遇到过同样的问题,我是这样解决的:

import json

with open("migrate.json", "rb") as read_file:
   data = json.load(read_file)

我遇到了同样的问题,当打印出从json文件中打开的json字符串时,发现json字符串以''开头,通过做一些研究,这是因为文件默认是用UTF-8解码的,通过将编码改为UTF-8 -sig,标记被剥离,加载json没有问题:

open('test.json', encoding='utf-8-sig')

我做了:

打开test.txt文件,写入数据 打开test.txt文件,读取数据

所以我没有在1点后关闭文件。

我添加了

outfile.close()

现在起作用了

你的代码产生了一个空的响应体,你会想要检查它或者捕获异常。有可能服务器响应了204 No Content响应,或者返回了一个非200范围的状态码(404 Not Found等)。检查这个。

注意:

没有必要使用simplejson库,Python中包含了与json模块相同的库。 没有必要解码从UTF8到unicode的响应,simplejson / json .loads()方法可以原生处理UTF8编码的数据。 pycurl的API非常古老。除非您对使用它有特定的要求,否则还有更好的选择。

无论是请求还是httpx都提供了更友好的api,包括JSON支持。如果可以,把你的电话换成:

import requests

response = requests.get(url)
response.raise_for_status()  # raises exception when not a 2xx response
if response.status_code != 204:
    return response.json()

当然,这并不能保护您免受不符合HTTP标准的URL的影响;当可能使用任意url时,检查服务器是否打算通过检查Content-Type头来给你JSON,并捕捉异常:

if (
    response.status_code != 204 and
    response.headers["content-type"].strip().startswith("application/json")
):
    try:
        return response.json()
    except ValueError:
        # decide how to handle a server that's misbehaving to this extent

在我的情况下,这是因为服务器偶尔会给出http错误。所以基本上偶尔我的脚本得到这样的响应,而不是预期的响应:

<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html>
<head><title>502 Bad Gateway</title></head>
<body bgcolor="white">
<h1>502 Bad Gateway</h1>
<p>The proxy server received an invalid response from an upstream server.<hr/>Powered by Tengine</body>
</html>

显然这不是json格式,试图调用.json()将产生JSONDecodeError:期望值:第1行第1列(char 0)

您可以打印导致此错误的确切响应,以便更好地调试。 例如,如果您正在使用请求,那么只需打印.text字段(在调用.json()之前)就可以了。