{
"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']
这抓住了一切,我不能做。
正确的方法是什么?
提前谢谢你帮我弄明白这一点。
公告
的内容是另一个JSON字符串。解码它,然后像处理外部对象一样访问它的内容。
您有嵌套的JSON数据;与'annoucement'
键关联的字符串本身就是另一个独立的嵌入式JSON文档。
您必须首先解码该字符串:
import json
replay_data = raw_replay_data['data']['video_info'][0]
announcement = json.loads(replay_data['announcement'])
print(announcement['content'])
然后从那里处理生成的字典。
在一行中-
>>> json.loads(data['data']['video_info'][0]['announcement'])['content']
'FOLLOW ME PLEASE'
为了帮助您了解如何访问数据(这样您就不必再次询问),您需要盯着数据看。
首先,让我们很好地展示您的数据。您可以使用json。转储(数据,缩进=4)
,也可以使用JSONLint之类的在线工具。通用域名格式。
{
'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数据,我在单独的行中列出了这些数据。
首先,找出数据所在的位置。您正在查找内容
键中的数据,该键可通过公告
键访问,该键是dicts列表中词典的一部分,可通过视频信息
键访问,而数据
又可访问该键。
因此,总而言之,使用以下“梯级”“下降”是“数据”的梯子——
数据
,字典首先,
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'
如果你将来有这种性质的疑问,这应该有望作为一个指南。
问题内容: { “status”: “200”, “msg”: “”, “data”: { “time”: “1515580011”, “video_info”: [ { “announcement”: ”{"announcement_id":"6","name":"INS\u8d26\u53f7","icon":"http:\\/\\/liveme.cms.ksmobile.net\\/live
问题内容: 如何从此json获取内容“请关注我”? 这抓住了所有的一切,我做不到。 什么是正确的方法? 预先感谢你帮助我解决此问题。 问题答案: 在一行中 为了帮助你了解如何访问数据(因此你无需再次询问),你需要凝视你的数据。 首先,让我们很好地布置你的数据。你可以使用,也可以使用之类的在线工具。 ***请注意,announcement键中的数据实际上是更多的 json数据,我已将它们放在单独的行
问题内容: 我正在尝试使用zippopotam.us获取特定城市的邮政编码。我有下面的代码可以正常工作,但是当我尝试访问返回的密钥时 完整的JSON输出: 谢谢你的帮助。 问题答案: 我没有意识到第一个嵌套元素实际上是一个数组。正确访问邮政编码密钥的方法如下:
问题内容: 假设我有json数据,例如 现在我正在从该json数据访问字段,例如: 如何以最有效的方式从给定的json数据访问第三个字段()? 不起作用 一种可能是我使用for循环构造字符串,然后进行eval评估,但是有没有有效的方法呢? 问题答案: 老实说,我无法理解您的问题。JSON已经结构化了,为什么需要更改结构? 在您的情况下,我将按以下方式访问它: 如果碰巧希望 遍历 数据,则需要: 更
我需要一些使用MapStruct映射嵌套POJO的帮助。我需要跳过/删除目标类中所有子类的特定字段。 例如,以下是我的目标POJO 所有这些子类——,,。。。包含一个字段“”,我想在映射时忽略它。这种结构使得这些类不共享包含此字段的公共基类——“”。 我创建的映射器如下所示: 这工作。 然而,当中的子类数量很大时,它会变得很乏味。我需要明确指定每个类。 有没有人能告诉我,这是否可以用一种更通用的方
我试图解析一个OpenAPI JSON文件,并访问值来构建一个rest模型类。我尝试使用对象映射器解析JSON文件,并将其发送到一个接收