多个list dict嵌套 如何快速获取某个list

腾讯云CDN日志的数据格式为:
data={"Data": [{"Resource": "all", "DetailData": [{"Name": "cdn.asd.com/asd/asdfg.mp4", "Value": 2972209657}, {"Name": "cdn.asd.com/asd/hjkl.jpg", "Value": 12856187}]}], "RequestId": "asd-erf-ghj-qwe-zxc"}

如何快速获取其中的一个list:
[{"Name": "cdn.asd.com/asd/asdfg.mp4", "Value": 2972209657}, {"Name": "cdn.asd.com/asd/hjkl.jpg", "Value": 12856187}]

我有比较笨的办法,就是一级级拿:

get_Data=[v for k,v in data.items() if k=="Data"]

得到get_Data值:
[[{'Resource': 'all', 'DetailData': [{'Name': 'cdn.asd.com/asd/asdfg.mp4', 'Value': 2972209657}, {'Name': 'cdn.asd.com/asd/hjkl.jpg', 'Value': 12856187}]}]]

get_Data_dict=get_Data[0][0]

得到get_Data_dict值:
{'Resource': 'all', 'DetailData': [{'Name': 'cdn.asd.com/asd/asdfg.mp4', 'Value': 2972209657}, {'Name': 'cdn.asd.com/asd/hjkl.jpg', 'Value': 12856187}]}

get_DetailData=[v for k,v in get_Data_dict.items() if k=="DetailData"][0]

得到最终值:
[{'Name': 'cdn.asd.com/asd/asdfg.mp4', 'Value': 2972209657}, {'Name': 'cdn.asd.com/asd/hjkl.jpg', 'Value': 12856187}]

比较繁琐,有没有比较优雅的办法?

阅读 2.4k
1 个回答

你的日志数据是结构化json数据,可以考虑使用json解析库, 比如ijson
假定json描述如下

{
  "earth": {
    "europe": [
      {"name": "Paris", "type": "city", "info": { ... }},
      {"name": "Thames", "type": "river", "info": { ... }},
      // ...
    ],
    "america": [
      {"name": "Texas", "type": "state", "info": { ... }},
      // ...
    ]
  }
}

获取 europe 列表 ,则用法这样

import ijson

f = urlopen('http://.../')
objects = ijson.items(f, 'earth.europe.item')
cities = (o for o in objects if o['type'] == 'city')
for city in cities:
    do_something_with(city)
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏