#python #json #python-3.x #python-2.7
#python #json #python-3.x #python-2.7
Вопрос:
Как анализировать динамические цифровые клавиши с помощью следующего json. Я могу сделать это вручную json_text['entities']['0']['uid']
, как я могу динамически выполнять итерации со всеми ключами и получать все идентификаторы uid
{
"entities": {
"0":{
"uid": "3769fcb3-8312-41b8-a5c9-3c24b6a9ce96"
},
"1":{
"uid": "3769fcb3-8312-41b8-a5c9-3c24b6a9ce97"
},
"2":{
"uid": "3769fcb3-8312-41b8-a5c9-3c24b6a9ce98"
}
"3":{
;
}
:
:
:
}
}
Код:
import os, json
import pandas as pd
path_to_json = '/home/sshuser/data/'
json_files = [pos_json for pos_json in os.listdir(path_to_json) if pos_json.endswith('.json')]
print(json_files)
# here I define my pandas Dataframe with the columns I want to get from the json
# we need both the json and an index number so use enumerate()
for index, js in enumerate(json_files):
with open(os.path.join(path_to_json, js)) as json_file:
json_text = json.loads(json_file.read())
uids= json_text['entities']['0']['uid']
print(seeMore)
Ответ №1:
вы можете это
import json
with open ("yourfile.json","r") as f:
json=json.load(f)
try:
a=0
while True:
print(json["entities"][str(a)]["uid"])
a =1
except KeyError:
pass
Ответ №2:
json_text['entities']
это dict. Вы можете использовать dict.items() для перебора пар ключей и значений.
for key, value in json_text['entities'].items(): # assume key 'entities' always exists
print(f"{key} --> {value.get('uid')}")
если key
это не важно, вы можете выполнить итерацию только .values()
вместо этого:
for value in json_text['entities'].values():
print(value.get('uid'))