6

Ошибка JSONDecodeError: Ожидалось значение: строка 1, столбец 1 (символ 0)

36

Я получаю ошибку <code>Expecting value: line 1 column 1 (char 0)</code> при попытке декодировать JSON.

URL, который я использую для API-запроса, работает нормально в браузере, но выдает эту ошибку при выполнении через CURL-запрос. Вот код, который я использую для CURL-запроса.

Ошибка возникает на строке <code>return simplejson.loads(response_json)</code>.

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)

Кто-нибудь может помочь понять, почему возникает эта ошибка и как ее исправить?

5 ответ(ов)

2

Не забудьте вызывать json.loads() на содержимом файла, а не на пути к файлу JSON. Пример того, как это следует делать:

json_file_path = "/path/to/example.json"

with open(json_file_path, 'r') as j:
    contents = json.loads(j.read())

Я думаю, многие из нас периодически совершают эту ошибку (включая меня):

contents = json.load(json_file_path)

Важно помнить, что json.load() предназначен для работы с объектом файл, а json.loads() — для работы со строкой JSON.

1

Проверьте содержимое data-body ответа, чтобы убедиться, что фактические данные присутствуют и дамп данных, кажется, хорошо отформатирован.

В большинстве случаев ошибка json.loads - JSONDecodeError: Expecting value: line 1 column 1 (char 0) возникает из-за следующих причин:

  • некорректные кавычки для JSON;
  • вывод XML/HTML (то есть строка, начинающаяся с <), или;
  • несовместимое кодирование символов.

В конечном итоге ошибка сообщает вам, что уже на первом символе строка не соответствует формату JSON.

Таким образом, если парсинг не удается, несмотря на то, что data-body выглядит как JSON на первый взгляд, попробуйте заменить кавычки в содержимом:

import sys
import json

struct = {}
try:
  try:  # попытаемся распарсить в словарь
    dataform = str(response_json).strip("'<>() ").replace('\'', '\"')
    struct = json.loads(dataform)
  except:
    print(repr(response_json))
    print(sys.exc_info())

Обратите внимание: кавычки внутри данных должны быть корректно экранированы.

0

При использовании библиотеки requests ошибка JSONDecodeError может возникнуть, если вы получаете HTTP-код ошибки, например 404, и пытаетесь разобрать ответ как JSON.

Чтобы избежать этой ситуации, вам следует сначала проверить код ответа на 200 (OK) или позволить библиотеке выбросить ошибку при возникновении проблемы. Я бы предпочел, чтобы ошибка была более понятной.

ПРИМЕЧАНИЕ: Как отметил Мартейн Питерс в комментариях, серверы могут возвращать JSON в случае ошибок (это зависит от реализации), поэтому проверка заголовка Content-Type является более надежным подходом.

0

Проверьте кодировку вашего файла и используйте соответствующий формат кодировки при его чтении. Это решит вашу проблему.

with open("AB.json", encoding='utf-8', errors='ignore') as json_data:
    data = json.load(json_data, strict=False)
0

У меня была такая же проблема при попытке прочитать JSON-файлы с помощью

json.loads("file.json")

Я решил проблему следующим образом:

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

Возможно, это поможет и в вашем случае.

Чтобы ответить на вопрос, пожалуйста, войдите или зарегистрируйтесь