Чтение JSON из файла?
Я чувствую головную боль только потому, что простое на вид, легкое утверждение вызывает некоторые ошибки в моем лице.
У меня есть файл json с именем 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.load(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]
Ответы
Ответ 1
Метод json.load()
(без "s" в "load") может читать файл напрямую:
import json
with open('strings.json') as f:
d = json.load(f)
print(d)
Вы использовали метод json.loads()
, который используется только для строковых аргументов.
Изменение: новое сообщение это совершенно другая проблема. В этом случае в этом файле есть недопустимый json. Для этого я бы порекомендовал запустить файл через валидатор json.
Существуют также решения для исправления json, как, например, Как автоматически исправить неверную строку JSON? ,
Ответ 2
Вот копия кода, которая отлично работает для меня
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 catch, потому что недействительный JSON вызовет сообщение об ошибке stacktrace.
Ответ 3
Проблема заключается в использовании выражения с:
with open('strings.json') as json_data:
d = json.load(json_data)
pprint(d)
Файл будет неявным образом закрыт. Нет необходимости снова называть json_data.close()
.
Ответ 4
В питоне 3 мы можем использовать метод ниже.
Читать из файла и конвертировать в JSON
import json
# Considering "json_list.json" is a json file
with open('json_list.json') as fd:
json_data = json.load(fd)
или же
import json
json_data = json.load(open('json_list.json'))
Использование с оператором автоматически закроет дескриптор открытого файла.
Строка в JSON
import json
json_data = json.loads('{"name" : "myName", "age":24}')
Ответ 5
Чтобы добавить это, сегодня вы можете использовать панды для импорта json:
https://pandas.pydata.org/pandas-docs/stable/generated/pandas.read_json.html Возможно, вы захотите осторожно использовать параметр orient.