我正在使用网站API来获取信息。它输出 100 个值。
在此数组中搜索特定值的最佳做法是什么?
数组看起来像这样:
{
"success":true,
"data":
{
"array":
[
{
"id":"1","name":"Value1"
},
{
"id":"2","name":"Value2"
}
]
}
}
Run Code Online (Sandbox Code Playgroud)
我尝试使用我在别处找到的这个片段来搜索数据,但它不起作用:
for name in (r.json()['data']['array'][0]['name']):
if r.json()['data']['array'][0] == s_name:
ident = r.json()['data']['array'][0]['id']
name = r.json()['data']['array'][0]['name']
print (name + ' - ' + ident)
else:
print ('Nothing was found.')
Run Code Online (Sandbox Code Playgroud)
因此,如果我试图参考Value1我将如何使用Python?
请注意:我是一个菜鸟开发者,第一次使用Json,对Python.
非常感谢所有帮助。
不确定那段代码来自哪里,但看起来很错误。
只需查看结构,您就可以执行以下操作:
for attrs in r.json()['data']['array']:
if attrs['name'] == s_name:
ident = attrs['id']
name = attrs['name']
print(name, '-', ident)
break
else:
print('Nothing found!')
Run Code Online (Sandbox Code Playgroud)
您的代码可以简化很多:
# no need to call `r.json` so many times, can simply save it to a variable
json_data = r.json()
for item in json_data["data"]["array"]:
if item["name"] == "Value1":
# do something...
Run Code Online (Sandbox Code Playgroud)
这是用于搜索的单行示例:
aaa = {
"success":True,
"data":
{
"array":
[
{
"id":"1","name":"Value1"
},
{
"id":"2","name":"Value2"
}
]
}
}
[a['name'] for a in aaa['data']['array'] if a['id']=='1']
Run Code Online (Sandbox Code Playgroud)
这将返回所有找到的案例,如果没有找到,则返回一个空数组