如何解决如何从 Json api 响应中减去键并检查是否有更多键,如果有,将它们放入列表中?
所以我有一个复杂的问题,我有一个带有密钥的 JSON API 响应:'persons' 中的 'key'
但在某些情况下有超过 1 个“键”,我尝试创建一个 for 循环来查看响应,但它会打印 20 次。此外,我不知道将这些“密钥”放在列表中或我可以访问它们的地方。
为了让它更容易一些,我从我的 .request 中得到了响应
{'id': 'a2b1109e-e142-4559-984c-3f9997b1db6a','externalId': None,'name': 'tyr','description': '','client': '','reference': '56345','isMonitoring': False,'monitoringSince': None,'hasRiskProfile': True,'riskProfile': 5,'monitorFrequency': 4,'mainBindable': None,'organizationId': '65647b97-5ada-4362-bb3f-cae016722be6','userId': 'dd3cc015-e5cf-4a03-9408-74b102900836','createDate': '2021-03-23T11:29:55.2027037Z','updateDate': '2021-03-23T11:29:55.2027039Z','lastMonitorDate': '2021-03-23T11:29:55.2027039Z','persons': [{'firstname': 'ya','surname': 'o','dateOfBirth': '','updatedWithIdinIdentificationRequestPerson': None,'relatedList': None,'updatedWithIdinIdentificationRequestPersonDate': None,'history': [],'fullname': 'ya o','key': '8b92c210-eee6-4ab2-a093-48e4428af7f8','searchResults': [],'requests': [],'createDate': '2021-03-23T11:29:57.3853552Z','updateDate': '2021-03-23T11:29:57.3853553Z','archivedDate': None,'isArchived': False,'hasPepSearchResults': False,'notes': []}],'businesses': [],'monitorIds': [],'addresses': [],'notifcations': [],'monitors': []}
每次的密钥数量可能不同,因此我需要检查返回的密钥是否已经存在,如果存在,则什么都不做,如果密钥不存在,则将该密钥保存在变量。
这里是有 2 个键“key”时的响应示例,
{'id': '44b2203b-b2c8-41f0-8fde-b697ec02a8c8','createDate': '2021-03-23T20:58:53.0345703Z','updateDate': '2021-03-23T20:58:53.0345705Z','lastMonitorDate': '2021-03-23T20:58:53.0345706Z','persons': [{'firstname': 'marnox','surname': 'bolier','fullname': 'marnox bolier','key': '68e4a9ad-2431-490f-a216-61a0cbd81c57','searchResults': [{'at': '2021-03-23T20:58:54.6796804Z','totalHits': 0,'type': None,'results': [{'paymentRequired': False,'service': None,'source': 'CIR','items': [],'count': 0},{'paymentRequired': False,'service': 'VaV61','source': 'Entity','count': 0}],'requestable': {'id': 'bf9dea30-2f4a-467a-a7b1-6765ceaee517','name': 'marnox bolier','createDate': '2021-03-23T20:58:55.5409494Z','updateDate': '2021-03-23T20:58:55.5409495Z','type': 'NotFoundPerson','sourceKey': 'A135D3C449EA15C66B6444611E2C97EC','picture': None,'properties': {},'resultKey': None,'data': None,'isArchived': False},'cachedResult': False}],'requests': [{'id': '57866866-85c4-43d8-8caa-b47a90b12be4','name': 'marnox bolier (TO UPDATE)','createDate': '2021-03-23T20:58:56.3090064Z','updateDate': '2021-03-23T20:58:56.3090064Z','sourceKey': 'AB1AD3379D84D5D2404CF8326CDA054D','isArchived': False}],'createDate': '2021-03-23T20:58:53.912784Z','updateDate': '2021-03-23T20:58:53.912784Z','hasPepSearchResults': True,'notes': []},{'firstname': 'marnix','fullname': 'marnix bolier','key': 'c0475154-530e-4802-b215-1d26a2c7f208','createDate': '2021-03-23T20:58:56.9078002Z','updateDate': '2021-03-23T20:58:56.9078002Z','monitors': []}
更新我解决了我的第一个问题,使用 for 循环获取超过 1 个键:
for persons in api_response['persons']:
print(persons['key'])
输出:
0b8eb227-0105-40a3-bc8b-8e3ef345a3f3
d9b68e7a-ffdd-44ea-86a4-ea4c541146b4
在这种情况下,我如何只保存最后一个结果
d9b68e7a-ffdd-44ea-86a4-ea4c541146b4
解决方法
假设您使用 requests
从 api 获取数据,您的响应将只附加一个 json()
函数。这意味着您可以执行以下操作:
import requests
response = requests.get("example.com/api/random/endpoint")
data = response.json()
json 函数反过来对响应的内容执行与 json.loads()
等效的操作。假设您的 API 返回一个 JSON 对象,这将被转换为字典(根据 json conversion table.
之后,您可以按照 go2nirvana 的回答并像操作任何 dict 一样操作这本词典。例如,使用 data.pop("key")
删除该键处的值、遍历字典或您可以对字典执行的任何其他操作。
诚然,您的问题有点含糊,我不确定您要如何处理收到的数据,但这就是您以易于在 Python 中使用的形式获取数据的方式。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。