Parsowanie wartości z pliku JSON?
Mam ten JSON w pliku:
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": [
"id": "valore"
],
"om_points": "value",
"parameters": [
"id": "valore"
]
}
Napisałem skrypt, który wypisuje cały tekst json:
json_data=open(file_directory).read()
data = json.loads(json_data)
pprint(data)
Jak mogę przeanalizować plik i wyodrębnić pojedyncze wartości?
8 answers
Myślę, że Ignacio mówi, że Twój plik JSON jest nieprawidłowy. Masz []
Kiedy powinieneś mieć {}
. {[3] } są dla list, {[4] } są dla słowników.
Oto jak powinien wyglądać Twój plik JSON, Twój plik JSON nawet by mi się nie załadował:
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": {
"id": "valore"
},
"om_points": "value",
"parameters": {
"id": "valore"
}
}
Wtedy możesz użyć swojego kodu:
import json
from pprint import pprint
with open('data.json') as f:
data = json.load(f)
pprint(data)
Z danymi można teraz również znaleźć wartości takie jak:
data["maps"][0]["id"]
data["masks"]["id"]
data["om_points"]
Wypróbuj je i zobacz, czy to ma sens.Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-05-04 08:22:57
Twoje data.json
powinno wyglądać tak:
{
"maps":[
{"id":"blabla","iscategorical":"0"},
{"id":"blabla","iscategorical":"0"}
],
"masks":
{"id":"valore"},
"om_points":"value",
"parameters":
{"id":"valore"}
}
Twój kod powinien brzmieć:
import json
from pprint import pprint
with open('data.json') as data_file:
data = json.load(data_file)
pprint(data)
Zauważ, że działa to tylko w Pythonie 2.6 i nowszych, ponieważ zależy to od with
-oświadczenie . W Pythonie 2.5 użyj from __future__ import with_statement
, w Pythonie odpowiedź Justina Peela, na której opiera się ta odpowiedź.
Możesz teraz również uzyskać dostęp do pojedynczych wartości, takich jak:
data["maps"][0]["id"] # will return 'blabla'
data["masks"]["id"] # will return 'valore'
data["om_points"] # will return 'value'
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-05-23 12:18:36
Odpowiedź Justina Peela jest naprawdę pomocna, ale jeśli używasz Pythona 3 czytanie JSON powinno być zrobione tak:
with open('data.json', encoding='utf-8') as data_file:
data = json.loads(data_file.read())
Uwaga: użyj json.loads
zamiast json.load
. W Pythonie 3, json.loads
pobiera parametr string. json.load
pobiera parametr obiektu podobny do pliku. data_file.read()
zwraca obiekt string.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-09-23 12:23:49
data = []
with codecs.open('d:\output.txt','rU','utf-8') as f:
for line in f:
data.append(json.loads(line))
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-05-12 20:47:46
"Ultra JSON" lub po prostu "ujson" poradzi sobie z posiadaniem []
w pliku JSON. Jeśli czytasz plik wejściowy JSON do programu jako listę elementów JSON; na przykład, [{[{}]}, {}, [], etc...]
ujson może obsłużyć dowolną kolejność list słowników, słowników list.
Ujson można znaleźć w indeksie pakietów Pythona , A API jest prawie identyczne z wbudowaną biblioteką Pythona json
.
Ujson jest również znacznie szybszy, jeśli ładujesz większe pliki JSON. Możesz zobaczyć szczegóły wydajności w porównaniu z innymi bibliotekami Pythona JSON w tym samym linku.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-02-10 04:45:38
Jeśli jesteś w Pythonie 3 Oto jak możesz to zrobić
{
"connection1": {
"DSN": "con1",
"UID": "abc",
"PWD": "1234",
"connection_string_python":"test1"
}
,
"connection2": {
"DSN": "con2",
"UID": "def",
"PWD": "1234"
}
}
Kod powinien wyglądać tak, jakby zakładał połączenie.plik json wygląda tak jak powyżej
connection_file = open('connection.json', 'r')
conn_string = json.load(connection_file)
conn_string['connection1']['connection_string_python'])
connection_file.close()
>>>test1
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-02-26 19:50:25
# Here you go with modified json file:
# data.json file :
{
"maps": [
{
"id": "blabla",
"iscategorical": "0"
},
{
"id": "blabla",
"iscategorical": "0"
}
],
"masks": [{
"id": "valore"
}],
"om_points": "value",
"parameters": [{
"id": "valore"
}]
}
# You can call or print data on console by using below lines
import json
from pprint import pprint
with open('data.json') as data_file:
data_item = json.load(data_file)
pprint(data_item)
print(data_item['parameters'][0]['id'])
#Output :
#pprint(data_item) output as :
{'maps': [{'id': 'blabla', 'iscategorical': '0'},
{'id': 'blabla', 'iscategorical': '0'}],
'masks': [{'id': 'valore'}],
'om_points': 'value',
'parameters': [{'id': 'valore'}]}
#print(data_item['parameters'][0]['id']) output as :
valore
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-11-07 01:53:18
W tym parsowaniu są dwa typy.
- parsowanie danych z pliku ze ścieżki systemowej
- parsowanie JSON ze ZDALNEGO ADRESU URL.
Z pliku możesz użyć następującego
import json
json = json.loads(open('/path/to/file.json').read())
value = json['key']
print json['value']
Ten arcticle wyjaśnia pełne parsowanie i pobieranie wartości przy użyciu dwóch scenariuszy.parsowanie JSON za pomocą Pythona
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-10-05 13:47:08