【发布时间】:2015-04-30 13:18:38
【问题描述】:
经过一些研究,我能够通过 RESTful API 从网络设备获取数据:
if sys.version_info >= (2,7,9):
import ssl
conn = httplib.HTTPSConnection('192.168.158.136', 443, context=ssl._create_unverified_context())
else:
conn = httplib.HTTPSConnection('192.168.158.136', 443)
headers = {"Authorization" : "Basic %s" % base64.b64encode('user:pass'),
"Content-Type" : "application/json"}
url="https://192.168.158.136/wapi/v1.2/network?_return_fields%2b=extattrs"
conn.request('GET', url, headers=headers)
response = conn.getresponse()
print response.read()
conn.close()
这会打印出我需要的 json 格式的对象列表:
[
{
"_ref": "network/ZG5zLm5ldHdvcmskMTAuMC4wLjAvMjQvMA:10.0.0.0/24/default",
"extattrs": {
"Location": {
"value": "NAU"
}
},
"network": "10.0.0.0/24",
"network_view": "default"
},
{
"_ref": "network/ZG5zLm5ldHdvcmskMTAuMS4xLjAvMjQvMA:10.1.1.0/24/default",
"extattrs": {
"Location": {
"value": "BTN"
}
},
"network": "10.1.1.0/24",
"network_view": "default"
},
{
"_ref": "network/ZG5zLm5ldHdvcmskMTAuMi4yLjAvMjQvMA:10.2.2.0/24/default",
"extattrs": {
"Location": {
"value": "TRT"
}
},
"network": "10.2.2.0/24",
"network_view": "default"
},
{
"_ref": "network/ZG5zLm5ldHdvcmskMTkyLjE2OC4wLjAvMTYvMA:192.168.0.0/16/default",
"extattrs": {
"Location": {
"value": "MCW"
}
},
"network": "192.168.0.0/16",
"network_view": "default"
}
]
现在我需要“以某种方式”将其格式化为仅包含“网络”和extattrs“位置”的内容的列表(并且只有位置,会有其他的,但我只需要位置)格式为:
网络位置,即
10.0.0.0/24 NAU 10.1.1.0/24 BTN 10.2.2.0/24 TRT 192.168.0.0/16 MCW我正在努力完成这项工作,即重新格式化我从查询中返回的 JSON 代码。
【问题讨论】:
-
使用 json 模块将其转换为 python 数据结构。你会得到一个字典列表。遍历列表,打印出键 `network' 的值。
-
@ForceBru :感谢您的编辑,但“admin:infoblox”已经是一个虚拟密码,什么都不是
-
@AndreDieball,我没碰它。有another edit 影响了这个密码