Ошибка JSONDecodeError: Ожидалось значение: строка 1, столбец 1 (символ 0)
Я получаю ошибку <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 ответ(ов)
Не забудьте вызывать 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.
Проверьте содержимое 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())
Обратите внимание: кавычки внутри данных должны быть корректно экранированы.
При использовании библиотеки requests
ошибка JSONDecodeError
может возникнуть, если вы получаете HTTP-код ошибки, например 404, и пытаетесь разобрать ответ как JSON.
Чтобы избежать этой ситуации, вам следует сначала проверить код ответа на 200 (OK) или позволить библиотеке выбросить ошибку при возникновении проблемы. Я бы предпочел, чтобы ошибка была более понятной.
ПРИМЕЧАНИЕ: Как отметил Мартейн Питерс в комментариях, серверы могут возвращать JSON в случае ошибок (это зависит от реализации), поэтому проверка заголовка Content-Type
является более надежным подходом.
Проверьте кодировку вашего файла и используйте соответствующий формат кодировки при его чтении. Это решит вашу проблему.
with open("AB.json", encoding='utf-8', errors='ignore') as json_data:
data = json.load(json_data, strict=False)
У меня была такая же проблема при попытке прочитать JSON-файлы с помощью
json.loads("file.json")
Я решил проблему следующим образом:
with open("file.json", "r") as read_file:
data = json.load(read_file)
Возможно, это поможет и в вашем случае.
Как обойти "datetime.datetime не сериализуем в JSON"?
Почему Python не может разобрать эти данные JSON? [закрыто]
Как записать данные JSON в файл?
Возврат JSON-ответа из представления Flask
Python3: JSON POST-запрос БЕЗ библиотеки requests