[英]Get a specific value in JSON and Python
I'm getting a JSON data from RESTCONF HTTPS request, using the following code. 我使用以下代码从RESTCONF HTTPS请求获取JSON数据。
https_request = 'https://' + host + '/restconf/data/Cisco-IOS-XE-native:native/interface/'
headers = {'Content-type': 'application/yang-data+json', 'Accept': 'application/yang-data+json'}
r = requests.get(https_request, auth=(user, password), headers=headers, verify=False)
print r.json()
The JSON file I got: 我得到的JSON文件:
{
"Cisco-IOS-XE-native:interface": {
"GigabitEthernet": [
{
"name": "1",
"description": "DON'T TOUCH ME",
"isis": {
"Cisco-IOS-XE-isis:metric": {
"value": 2
}
....
},
{
"name": "2",
"isis": {
"Cisco-IOS-XE-isis:metric": {
"value": 4
} ....
},
{
"name": "3",
"shutdown": [
null
],
"isis": {
"Cisco-IOS-XE-isis:metric": {
"value": 7
}....
}
],
"Loopback": [
{
"name": 0,
"isis": {
"Cisco-IOS-XE-isis:metric": {
"value": 1
}
],
"Tunnel": [
{
"name": 0,
"isis": {
"Cisco-IOS-XE-isis:metric": {
"value": 3
}....
}
]
}
Basically, I want my function to return the field's "value"
of isis
of each interface. 基本上,我希望函数返回每个接口的
isis
字段的"value"
。 I tried the following code for GigabitEthernet
: 我为
GigabitEthernet
尝试了以下代码:
value = r.json()['Cisco-IOS-XE-native:interface']['GigabitEthernet'][0]['isis']['metric']['value']
I got this error: 我收到此错误:
print Router_1.get_isis_metric()['Cisco-IOS-XE-native:interface']['GigabitEthernet'][0]['isis']['metric']['isis']
KeyError: 'metric'
I think, you have misspelled metric
for Cisco-IOS-XE-isis:metric
我想,你有拼写错误
metric
对Cisco-IOS-XE-isis:metric
Try : 尝试:
value = r.json()['Cisco-IOS-XE-native:interface']['GigabitEthernet'][0]['isis']['Cisco-IOS-XE-isis:metric']['value']
Edit 1 编辑1
for index in range(len(r.json()['Cisco-IOS-XE-native:interface']['GigabitEthernet'])):
value = r.json()['Cisco-IOS-XE-native:interface']['GigabitEthernet'][index]['isis']['Cisco-IOS-XE-isis:metric']['value']
print(value)
Using a list comprehension, where you iterate over the list of dictionaries and collect the value for each interface, example for GigabitEthernet
使用列表推导,在其中迭代字典列表并收集每个接口的值,例如
GigabitEthernet
dct = {
"Cisco-IOS-XE-native:interface": {
"GigabitEthernet": [
{
"name": "1",
"description": "DON'T TOUCH ME",
"isis": {
"Cisco-IOS-XE-isis:metric": {
"value": 2
}}
},
{
"name": "2",
"isis": {
"Cisco-IOS-XE-isis:metric": {
"value": 4
}}
},
{
"name": "3",
"shutdown": [
None
],
"isis": {
"Cisco-IOS-XE-isis:metric": {
"value": 7
}}
}
]}}
result = [item['isis']["Cisco-IOS-XE-isis:metric"]['value'] for item in dct['Cisco-IOS-XE-native:interface']['GigabitEthernet']]
The output will be 输出将是
[2, 4, 7]
Or to collect values for all interfaces, you can loop over the interfaces and collect the value for each interface 或者要收集所有接口的值,您可以遍历接口并收集每个接口的值
interfaces = ['GigabitEthernet', 'Loopback', 'Tunnel']
result = [item['isis']["Cisco-IOS-XE-isis:metric"]['value'] for interface in interfaces for item in dct['Cisco-IOS-XE-native:interface'][interface]]
print(result)
The output will be 输出将是
[2, 4, 7, 1, 3]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.