fjf*_*fjf 3 arrays json multidimensional-array aws-cli jmespath
由于 aws 日志 get-query-results,我有以下数据结构:
{
"status": "Complete",
"statistics": {
"recordsMatched": 2.0,
"recordsScanned": 13281.0,
"bytesScanned": 7526096.0
},
"results": [
[
{
"field": "time",
"value": "2019-01-31T21:53:01.136Z"
},
{
"field": "requestId",
"value": "a9c233f7-0b1b-3326-9b0f-eba428e4572c"
},
{
"field": "logLevel",
"value": "INFO"
},
{
"field": "callerId",
"value": "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
}
],
[
{
"field": "time",
"value": "2019-01-25T13:13:01.062Z"
},
{
"field": "requestId",
"value": "a4332628-1b9b-a9c2-0feb-0cd4a3f7cb63"
},
{
"field": "logLevel",
"value": "INFO"
},
{
"field": "callerId",
"value": "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
}
],
]
}
Run Code Online (Sandbox Code Playgroud)
AWS CLI 支持 JMESPath 语言来过滤输出。我需要应用一个查询字符串,在返回的“结果”中过滤包含“callerId”作为“字段”的对象,检索“value”属性并获得以下输出:
[
{
callerId: "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
},
{
callerId: "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
}
]
Run Code Online (Sandbox Code Playgroud)
我做的第一步是使用查询字符串来展平结果数组:results[]
这将读取其他根属性(状态、统计信息),并仅返回一个包含所有 {field: ..., value: ...} 类似对象的大数组。但在此之后,我无法正确过滤那些与 field=="callerId" 匹配的对象。除其他外,我尝试了以下表达式但没有成功:
'results[][?field=="callerId"]'
'results[][*][?field=="callerId"]'
'results[].{ callerId: @[?field=="callerId"].value }'
Run Code Online (Sandbox Code Playgroud)
我不是 JMESPath 方面的专家,我正在做 jmespath.org 网站的教程,但无法使其工作。
谢谢!
使用 jq 是一件好事,因为它是更完整的语言,但如果您想使用 JMES Path 来完成这里的解决方案:
results[*][?field=='callerId'].{callerId: value}[]
要得到:
[
{
"callerId": "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
},
{
"callerId": "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
}
]
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9323 次 |
| 最近记录: |