ホームページ >バックエンド開発 >Python チュートリアル >複雑な JSON 構造からネストされた値を抽出するにはどうすればよいでしょうか?
ネストされた JSON 値の抽出
問題:
JSON データを解析するときに、次のような問題が発生する可能性があります。次のような複雑でネストされた構造:
<code class="json">{'name': 'ns1:timeSeriesResponseType', 'declaredType': 'org.cuahsi.waterml.TimeSeriesResponseType', 'scope': 'javax.xml.bind.JAXBElement$GlobalScope', 'value': {'queryInfo': {'creationTime': 1349724919000, 'queryURL': 'http://waterservices.usgs.gov/nwis/iv/', 'criteria': {'locationParam': '[ALL:103232434]', 'variableParam': '[00060, 00065]'}, 'note': [{'value': '[ALL:103232434]', 'title': 'filter:sites'}, {'value': '[mode=LATEST, modifiedSince=null]', 'title': 'filter:timeRange'}, {'value': 'sdas01', 'title': 'server'}]}}, 'nil': False, 'globalScope': True, 'typeSubstituted': False}</code>
「creationTime」フィールドなどの特定の値を抽出したいとします。
解決策:
1.データ構造をナビゲートする:
「creationTime」値を抽出するには、キーを使用してネストされた構造をナビゲートする必要があります:
<code class="python">my_dict['key1']['key2']['key3']</code>
2。コード例:
「creationTime」値を取得するには、次のコードを使用します:
<code class="python">creation_time = my_dict['value']['queryInfo']['creationTime']</code>
3。データへのパスの決定:
特定のデータ要素へのパスを決定するには、JSON 応答の構造を調べます:
4.より一般的なアプローチ:
不明なネストされた JSON 構造が見つかった場合は、再帰関数を使用して移動し、目的の値を取得できます:
<code class="python">def get_nested_value(data, path): if isinstance(data, dict): if path[0] in data: return get_nested_value(data[path[0]], path[1:]) else: return None # Raise an error if the key doesn't exist elif isinstance(data, list): if len(path) == 0: return data else: return get_nested_value(data[path[0]], path[1:]) else: return data value = get_nested_value(my_dict, ['value', 'queryInfo', 'creationTime'])</code>
以上が複雑な JSON 構造からネストされた値を抽出するにはどうすればよいでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。