У меня есть этот JSON в файле:
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": [
"id": "valore"
],
"om_points": "value",
"parameters": [
"id": "valore"
]
}
Я написал этот скрипт для печати всех данных JSON:
import json
from pprint import pprint
with open('data.json') as f:
data = json.load(f)
pprint(data)
Эта программа вызывает исключение, хотя:
Traceback (most recent call last):
File "<pyshell#1>", line 5, in <module>
data = json.load(f)
File "/usr/lib/python3.5/json/__init__.py", line 319, in loads
return _default_decoder.decode(s)
File "/usr/lib/python3.5/json/decoder.py", line 339, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/usr/lib/python3.5/json/decoder.py", line 355, in raw_decode
obj, end = self.scan_once(s, idx)
json.decoder.JSONDecodeError: Expecting ',' delimiter: line 13 column 13 (char 213)
Как я могу проанализировать JSON и извлечь его значения?
Ответы:
Ваши данные не в формате JSON . У вас есть,
[]
когда вы должны иметь{}
:[]
предназначены для массивов JSON, которые называютсяlist
в Python{}
предназначены для объектов JSON, которые вызываютсяdict
в PythonВот как должен выглядеть ваш JSON-файл:
Тогда вы можете использовать свой код:
С данными теперь вы также можете найти такие значения:
Попробуйте это и посмотрите, начнет ли это иметь смысл.
источник
u'
перед каждым ключом. Есть идеи почему?Вы
data.json
должны выглядеть так:Ваш код должен быть:
Обратите внимание, что это работает только в Python 2.6 и выше, так как это зависит от
with
-statement . В Python 2.5 используйтеfrom __future__ import with_statement
, в Python <= 2.4, см . Ответ Джастина Пила, на котором основан этот ответ.Теперь вы также можете получить доступ к отдельным значениям, например так:
источник
data_file
open
дольше, чем необходимо.pprint
вwith
-context дольше сохраняетdata_file
открытость.data["om_points"]
,data["masks"]["id"]
. Идея в том, что вы можете достичь любого уровня в словаре, указав «ключевые пути». Если вы получаетеKeyError
исключение, это означает, что ключ не существует в пути. Посмотрите на опечатки или проверьте структуру вашего словаря.Ответ Джастина Пила действительно полезен, но если вы используете Python 3, чтение JSON должно быть сделано следующим образом:
Примечание: используйте
json.loads
вместоjson.load
. В Python 3json.loads
принимает строковый параметр.json.load
принимает файловый параметр объекта.data_file.read()
возвращает строковый объект.Честно говоря, я не думаю, что в большинстве случаев проблема заключается в загрузке всех данных JSON в память.
источник
json.load
избегать в пользу.loads
в Python 3?load
.источник
json.loads
не декодирует несколько объектов JSON. В противном случае вы получите ошибку «Extra Data».}
,]
или"
). Следовательно, вы действительно можете объединить несколько объектов в одну строку или один файл, без двусмысленности. Проблема здесь в том, что синтаксический анализатор, ожидающий один объект, завершается ошибкой, когда ему передано более одного объекта..jsonl
(строки json), объекты разделяются символом новой строки, что делает предварительную обработку для анализа тривиальной и позволяет легко разбивать / пакетировать файлы, не беспокоясь о маркерах начала / конца.«Ultra JSON» или просто «ujson» могут обрабатывать
[]
ввод в ваш файл JSON. Если вы читаете входной файл JSON в вашу программу в виде списка элементов JSON; например,[{[{}]}, {}, [], etc...]
ujson может обрабатывать произвольный порядок списков словарей, словари списков.Вы можете найти ujson в индексе пакета Python, и API почти идентичен встроенной
json
библиотеке Python .ujson также намного быстрее, если вы загружаете большие файлы JSON. Вы можете увидеть детали производительности в сравнении с другими библиотеками Python JSON по той же ссылке.
источник
Если вы используете Python3, вы можете попробовать изменить (
connection.json
файл) JSON на:Затем с помощью следующего кода:
источник
with
лучше использовать утверждениеЗдесь вы идете с измененным
data.json
файлом:Вы можете позвонить или распечатать данные на консоли, используя следующие строки:
Ожидаемый результат для
print(data_item['parameters'][0]['id'])
:Ожидаемый результат для
print(data_item['parameters'][0]['id'])
:источник
Есть два типа в этом разборе.
Из файла вы можете использовать следующее
Эта статья объясняет полный анализ и получение значений с использованием двух сценариев. Разбор JSON с использованием Python
источник
Как пользователь Python3 ,
Разница между
load
иloads
методами важна, особенно когда вы читаете данные json из файла.Как указано в документации:
json.load:
json.loads:
Метод json.load может непосредственно читать открытый документ json, так как он способен читать двоичный файл.
В результате ваши данные JSON доступны в формате, указанном в соответствии с таблицей преобразования:
https://docs.python.org/3.7/library/json.html#json-to-py-table
источник