arrays - 嵌套数组结构的 JMESPath 查询
问题描述
由于 aws logs 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"
}
],
]
}
AWS CLI 支持用于过滤输出的 JMESPath 语言。我需要应用一个查询字符串,在返回的“结果”中过滤包含“callerId”作为“字段”的对象,检索“值”属性并获得以下输出:
[
{
callerId: "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
},
{
callerId: "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
}
]
我要做的第一步是使用查询字符串来平整结果数组:results[]
这将读取其他根属性(状态、统计信息)并仅返回一个包含所有 {field: ..., value: ...} 类似对象的大数组。但在此之后,我无法正确过滤那些匹配 field=="callerId" 的对象。除其他外,我尝试了以下表达式但没有成功:
'results[][?field=="callerId"]'
'results[][*][?field=="callerId"]'
'results[].{ callerId: @[?field=="callerId"].value }'
我不是 JMESPath 方面的专家,我正在做 jmespath.org 网站的教程,但无法让它工作。
谢谢!
解决方案
我无法完全重现,因为我的日志流中没有相同的日志,但我能够使用 jq 并将示例 JSON 对象放入文件中来做到这一点
cat sample_output.json | jq '.results[][] | select(.field=="callerId") | .value'
输出:
"a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
"a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
您可以将 aws cli 的输出通过管道传输到 jq。
我能够非常接近本机 JMESPath 查询并使用此站点 http://jmespath.org/examples.html#filtering-and-selecting-nested-data中的内置编辑器
results[*][?field==`callerId`][]
输出:
[
{
"field": "callerId",
"value": "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
},
{
"field": "callerId",
"value": "a9b0f9c2-eb42-3986-33f7-8e450b1b72cf"
}
]
但我不确定如何callerId
成为键和值成为另一个键的值。
推荐阅读
- here-api - HERE Places (Search) API - 类别系统文档和 API 响应之间的差异
- javascript - 如何将图像和数组与本机反应一起发布到后端?
- angular - 了解使用 Angular 制作的 Web 应用程序的性能
- node.js - 在邮递员“null”中发出删除请求后得到这样的响应?
- python - BLE 数据在 Python 中转换为 Bytearray
- reactjs - 即使没有剩余空间,Froala 工具栏弹出窗口也会出现在底部
- android - 在存储库类中使用 dagger-hilt
- scheduled-tasks - 如何创建一个 Teamcity 构建触发器,该触发器将在作业 A 完成后每周运行一次作业 B,其中 A 每天运行
- autodesk-forge - Autodesk Forge 查看器:直接加载 SVF?
- twitter-bootstrap-3 - 如何从 Fullcalendar 中删除 fc-time?