我正在使用boto3向我描述我的管道.它以非常好奇的形式回复了一个回复 –
{'ResponseMetadata': {'HTTPStatusCode': 200,
'RequestId': '2c42a320-c6ab-11e5-a021-afa8e3e7ca24'},
u'pipelineDescriptionList': [{u'fields': [{u'key': u'key1', u'stringValue': u'AIDAIxxxxxxNWNI6I'},
{u'key': u'key2', u'stringValue': u'2016-01-29T13:32:09'},
{u'key': u'key3', u'stringValue': u'ABCD'},
{u'key': u'key4', u'stringValue': u'PIPELINE'}],
u'name': u'ABCD',
u'pipelineId': u'df-03442XXXXAZTRKE4NNK',
u'tags': []},
{u'fields': [{u'key': u'key1',u'stringValue': u'2016-01-29T11:26:02'},
{u'key': u'key2', u'stringValue': u'[{"key":"jobrun","value":"RzIN"},{"key":"env","value":"prod"}]'},
{u'key': u'key3', u'stringValue': u'2016-01-29T11:25:20'},
{u'key': u'key4', u'stringValue': u'PIPELINE'}],
u'name': u'test-pipeline',
u'pipelineId': u'df-006474936ZXRQ238Q70O',
u'tags': [{u'key': u'jobrun', u'value': u'RWssN'},{u'key': u'env', u'value': u'prod'}]}]}
现在我有兴趣获得管道’ABCD的key2值.如果我试图以最直观的方式获取它,它会变得非常混乱,因为我将不得不遍历每个pipelineDescriptionList列表项,遍历’fields’中的每个列表项,检查哪个键等于key2,并获取stringValue.
我的问题是,我们实际上是否期望处理这个烂摊子?或者是否有一些Python魔法可以让我的任务更优雅?
最佳答案 一种选择是使用与boto3捆绑在一起的
jmespath.它是一个非常强大的工具,用于处理类似JSON的数据结构.
例如,如果您在上面显示的响应绑定到变量响应,则可以执行以下操作:
jmespath.search("pipelineDescriptionList[?name == 'ABCD'].fields[] | [?key == 'key2'].stringValue", response)
将返回:
[u'2016-01-29T13:32:09']
可能有更好的方法来做到这一点,这只是快速切入它.您还可以编译这些表达式,以便使用相同的查询进行多次搜索,从而提高效率.