python – 获得Boto3响应字典值的优雅方式

我正在使用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']

可能有更好的方法来做到这一点,这只是快速切入它.您还可以编译这些表达式,以便使用相同的查询进行多次搜索,从而提高效率.

点赞