Чтение JSON из файла
Описание проблемы:
Я столкнулся с проблемой при попытке прочитать JSON-файл в Python. У меня есть файл с именем strings.json, который выглядит следующим образом:
"strings": [{"-name": "city", "#text": "City"}, {"-name": "phone", "#text": "Phone"}, ...,
{"-name": "address", "#text": "Address"}]
Мне нужно просто загрузить данный JSON-файл, но когда я использую следующий код, он не работает:
import json
from pprint import pprint
with open('strings.json') as json_data:
d = json.loads(json_data)
json_data.close()
pprint(d)
В консоли отображается следующая ошибка:
Traceback (most recent call last):
File "/home/.../android/values/manipulate_json.py", line 5, in <module>
d = json.loads(json_data)
File "/usr/lib/python2.7/json/__init__.py", line 326, in loads
return _default_decoder.decode(s)
File "/usr/lib/python2.7/json/decoder.py", line 366, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
TypeError: expected string or buffer
[Finished in 0.1s with exit code 1]
Если я заменю json.loads
на json.load
, то получаю другую ошибку:
Traceback (most recent call last):
File "/home/.../android/values/manipulate_json.py", line 5, in <module>
d = json.load(json_data)
File "/usr/lib/python2.7/json/__init__.py", line 278, in load
**kw)
File "/usr/lib/python2.7/json/__init__.py", line 326, in loads
return _default_decoder.decode(s)
File "/usr/lib/python2.7/json/decoder.py", line 369, in decode
raise ValueError(errmsg("Extra data", s, end, len(s)))
ValueError: Extra data: line 829 column 1 - line 829 column 2 (char 18476 - 18477)
[Finished in 0.1s with exit code 1]
Прошу помощи в решении данной проблемы. Как правильно прочитать JSON-файл в Python?
3 ответ(ов)
Вот пример кода, который работает у меня без проблем:
import json
with open("test.json") as json_file:
json_data = json.load(json_file)
print(json_data)
При этом данные имеют следующий формат:
{
"a": [1, 3, "asdf", true],
"b": {
"Hello": "world"
}
}
Рекомендую обернуть строку с json.load в блок try-except, так как некорректный JSON может привести к возникновению ошибки и стек-трейсу. Пример:
import json
try:
with open("test.json") as json_file:
json_data = json.load(json_file)
print(json_data)
except json.JSONDecodeError as e:
print("Ошибка при декодировании JSON:", e)
except FileNotFoundError:
print("Файл не найден. Проверьте путь к 'test.json'.")
Таким образом, вы сможете обработать ошибки более аккуратно.
Проблема заключается в использовании оператора with
:
with open('strings.json') as json_data:
d = json.load(json_data)
print(d)
Файл будет автоматически закрыт после завершения блока with
. Таким образом, нет необходимости снова вызывать json_data.close()
.
В Python 3 мы можем использовать следующий метод.
Чтение из файла и преобразование в JSON
import json
from pprint import pprint
# Предполагаем, что "json_list.json" - это файл в формате JSON
with open('json_list.json') as fd:
json_data = json.load(fd)
pprint(json_data)
Оператор with автоматически закроет открытый файловый дескриптор после завершения блока кода.
Строка в JSON
import json
from pprint import pprint
json_data = json.loads('{"name" : "myName", "age":24}')
pprint(json_data)
Таким образом, вы можете легко читать JSON-данные из файла или преобразовывать строку в JSON-объект, используя модуль json
в Python.
Как обойти "datetime.datetime не сериализуем в JSON"?
Почему Python не может разобрать эти данные JSON? [закрыто]
Как записать данные JSON в файл?
Возврат JSON-ответа из представления Flask
Ошибка JSONDecodeError: Ожидалось значение: строка 1, столбец 1 (символ 0)