python提取json嵌套字段_Python-访问任意嵌套的JSON数据中的特定字段

小编典典

在一行中

>>> 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键中的数据实际上是更多的 json数据,我已将它们放在单独的行中。

首先,找出你的数据所在的位置。你正在寻找content密钥中的数据,该数据可以通过announcement密钥进行访问,密钥是字典列表中字典的一部分,字典可以在video_info密钥列表中进行访问,字典又可以通过密钥进行访问data。

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

data, 一本字典

video_info,字典列表

announcement,字典列表中第一个字典中的一个字典

content 作为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'

如果你将来有这种性质的疑问,希望可以将其作为指南。

2020-02-15

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值