我正在尝试使用Python Flask处理JSON数据。
以下是我的数据:
[
{ 'className': 'BoardGame',
'fields': {
'objectId': {'type': 'String'},
'playerName': {'type': 'String'},
'cheatMode': {'type': 'Boolean'},
'score': {'type': 'Number'},
'updatedAt': {'type': 'Date'},
'createdAt': {'type': 'Date'}
},
'classLevelPermissions': {
'addField': {'*': True},
'create': {'*': True}, 'get': {'*': True},
'update': {'*': True}, 'find': {'*': True},
'delete': {'*': True}
}
},
{ 'className': 'RPGGAme',
'fields': {
'objectId': {'type': 'String'},
'GameId': {'type': 'String'},
'robotName': {'type': 'String'},
'updatedAt': {'type': 'Date'},
'createdAt': {'type': 'Date'}
},
'classLevelPermissions': {
'addField': {'*': True},
'create': {'*': True}, 'get': {'*': True},
'fields': {'*': True}, 'find': {'*': True},
'delete': {'*': True}
}
}
]
问题是由于[]
和{}
的复杂格式,我无法获得相应的数据
这是我想要的:
[0]["className"]: "BoardGame" <---String
[0]["fields"]: ["objectId","playerName","cheatMode"....] <-- List Of String
[1]["className"]: "RPGGame" <---String
[1]["fields"]: ["objectId","GameId",....] <-- List Of String
因此,我尝试了以下代码:
def findkeys(node, kv):
if isinstance(node, list):
for i in node:
for x in findkeys(i, kv):
yield x
elif isinstance(node, dict):
if kv in node:
yield node[kv]
for j in node.values():
for x in findkeys(j, kv):
yield x
但是,它只能找到特殊键的值,但不能设置范围(我所说的范围是第一个“{}
”作为数组0+第二个“{}
”作为数组1+classLevelPermissions中的“fields”不会参与结果,某种意义上我猜是深度级别)。我还是不能解决问题,得到我想要的。你知道吗
如何设置深度并放入相应的数组,例如[0],[1]?你知道吗
试试这个:
然后:
相关问题 更多 >
编程相关推荐