我得到错误期望值:第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)

当前回答

当你想在python中加载json文件时,这是我发现的最简单的解决方案

import json
data = json.load(open('file_name.json'))

如果给出错误,表示字符在X和Y位置不匹配,则只需在左圆括号内添加encoding='utf-8'

data = json.load(open('file_name.json', encoding='utf-8'))

解释 Open打开文件并读取稍后在json.load中解析的包含。

请注意,使用与open()作为f比上述语法更可靠,因为它确保文件在执行后关闭,完整的语法将是

with open('file_name.json') as f:
    data = json.load(f)

其他回答

如果您是Windows用户,Tweepy API可以在数据对象之间生成空行。由于这种情况,您可能会得到“JSONDecodeError: expected value: line 1 column 1 (char 0)”错误。要避免此错误,可以删除空行。

例如:

 def on_data(self, data):
        try:
            with open('sentiment.json', 'a', newline='\n') as f:
                f.write(data)
                return True
        except BaseException as e:
            print("Error on_data: %s" % str(e))
        return True

参考: Twitter流API从None给出JSONDecodeError(“期望值”,s, err.value)

检查响应数据体,是否有实际数据,数据转储格式是否正确。

在大多数情况下,你的json。JSONDecodeError:期望值:第1行第1列(字符0)错误是由于:

非json格式引用 XML/HTML输出(即以<开头的字符串),或 不兼容的字符编码

最终,该错误告诉您,在第一个位置,字符串已经不符合JSON。

因此,如果解析失败,尽管有一个乍一看像JSON的数据体,尝试替换数据体的引号:

import sys, json
struct = {}
try:
  try: #try parsing to dict
    dataform = str(response_json).strip("'<>() ").replace('\'', '\"')
    struct = json.loads(dataform)
  except:
    print repr(resonse_json)
    print sys.exc_info()

注意:数据中的引号必须正确转义

我在一个基于python的web API的响应.text中收到了这样一个错误,但它把我带到了这里,所以这可能会帮助其他人解决类似的问题(在使用请求时,很难在搜索中过滤响应和请求问题..)

在请求数据arg上使用JSON .dumps()创建一个正确转义的JSON字符串,然后再发布,为我修复了这个问题

requests.post(url, data=json.dumps(data))

我有同样的问题,试图读取json文件

json.loads("file.json")

我用

with open("file.json", "r") as read_file:
   data = json.load(read_file)

也许这个对你有帮助

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

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