在 Python 中解析来自嵌套 JSON 响应的多条记录 [重复]
原文标题 :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']
。
这样做的正确方法是什么?
提前感谢您帮助我解决这个问题。
回复
我来回复-
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
键又可以访问。因此,总而言之,使用以下“梯级”“下降”作为“数据”的阶梯 –
- 数据,字典
- video_info , a list of dicts
- 公告,字典列表的第一个字典中的字典
- 作为 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年前 -
♦ 评论
你已经嵌套了 JSON 数据;与
'annoucement'
键关联的字符串本身就是另一个单独的嵌入 JSON 文档。您必须先解码该字符串:
import json replay_data = raw_replay_data['data']['video_info'][0] announcement = json.loads(replay_data['announcement']) print(announcement['content'])
然后从那里处理生成的字典。
2年前 -
Ignacio Vazquez-Abrams 评论
"announcement"
的内容是另一个JSON字符串。对其进行解码,然后像处理外部对象一样访问其内容。2年前