在 Python 中解析来自嵌套 JSON 响应的多条记录 [重复]

青葱年少 python 651

原文标题Parsing Multiple records from Nested JSON Response in Python [duplicate]

这个问题在这里已经有了答案:如何从 JSON 响应中提取单个值? (5 个回答) 3 年前关闭。

{
  "status": "200",
  "msg": "",
  "data": {
    "time": "1515580011",
    "video_info": [
      {
          "announcement": "{\"announcement_id\":\"6\",\"name\":\"INS\\u8d26\\u53f7\",\"icon\":\"http:\\\/\\\/liveme.cms.ksmobile.net\\\/live\\\/announcement\\\/2017-08-18_19:44:54\\\/ins.png\",\"icon_new\":\"http:\\\/\\\/liveme.cms.ksmobile.net\\\/live\\\/announcement\\\/2017-10-20_22:24:38\\\/4.png\",\"videoid\":\"15154610218328614178\",\"content\":\"FOLLOW ME PLEASE\",\"x_coordinate\":\"0.22\",\"y_coordinate\":\"0.23\"}",
          "announcement_shop": "",

如何从这个 json 中获取内容“请跟我来”?

replay_data = raw_replay_data['data']['video_info'][0]
announcement = replay_data['announcement']

这把什么都抢了['announcement']我做不到['announcement']['content']

这样做的正确方法是什么?

提前感谢您帮助我解决这个问题。

原文链接:https://stackoverflow.com//questions/71919491/parsing-multiple-records-from-nested-json-response-in-python

回复

我来回复
  • cs95的头像
    cs95 评论

    在一行 –

    >>> json.loads(data['data']['video_info'][0]['announcement'])['content']
    'FOLLOW ME PLEASE'
    

    为了帮助您了解如何访问数据(因此您不必再次询问),您需要盯着您的数据。

    首先,让我们很好地布置您的数据。您可以使用json.dumps(data, indent=4),也可以使用 JSONLint.com 之类的在线工具。

    {
        'data': {
            'time': '1515580011',
            'video_info': [{
                'announcement': (    # ***
                """{
                    "announcement_id": "6",
                    "name": "INS\\u8d26\\u53f7",
                    "icon": "http:\\\\/\\\\/liveme.cms.ksmobile.net\\\\/live\\\\/announcement\\\\/2017-08-18_19:44:54\\\\/ins.png",
                    "icon_new": "http:\\\\/\\\\/liveme.cms.ksmobile.net\\\\/live\\\\/announcement\\\\/2017-10-20_22:24:38\\\\/4.png",
                    "videoid": "15154610218328614178",
                    "content": "FOLLOW ME PLEASE",
                    "x_coordinate": "0.22",
                    "y_coordinate": "0.23"
                }"""),
                'announcement_shop': ''
            }]
        },
        'msg': '',
        'status': '200'
    } 
    

    *** 注意announcement键中的数据实际上是morejson数据,我已经在单独的行中进行了布局。

    首先,找出您的数据所在的位置。您正在查找content键中的数据,该键由announcement键访问,它是字典列表中字典的一部分,可以通过video_info键访问,而data键又可以访问。

    因此,总而言之,使用以下“梯级”“下降”作为“数据”的阶梯 –

    1. 数据,字典
    2. video_info , a list of dicts
    3. 公告,字典列表的第一个字典中的字典
    4. 作为 json 数据一部分的内容。

    第一的,

    i = data['data']
    

    下一个,

    j = i['video_info']
    

    下一个,

    k = j[0] # since this is a list
    

    如果你只想要第一个元素,这就足够了。否则,您需要迭代:

    for k in j:
        ...
    

    下一个,

    l = k['announcement']
    

    现在,l是 JSON 数据。加载它 –

    import json
    m = json.loads(l)
    

    最后,

    content = m['content']
    
    print(content)
    'FOLLOW ME PLEASE'
    

    如果您将来有这种性质的疑问,这应该可以作为指南。

    2年前 0条评论
  • ♦的头像
    评论

    你已经嵌套了 JSON 数据;与'annoucement'键关联的字符串本身就是另一个单独的嵌入 JSON 文档。

    您必须先解码该字符串:

    import json
    
    replay_data = raw_replay_data['data']['video_info'][0]
    announcement = json.loads(replay_data['announcement'])
    print(announcement['content'])
    

    然后从那里处理生成的字典。

    2年前 0条评论
  • Ignacio Vazquez-Abrams的头像
    Ignacio Vazquez-Abrams 评论

    "announcement"的内容是另一个JSON字符串。对其进行解码,然后像处理外部对象一样访问其内容。

    2年前 0条评论