Как анализировать динамические ключи json в Python

#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'))