- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对 jq
很陌生这篇文章是因为不了解背后的机制 jq
.
我可以开发一个 bash 脚本,它可以做我想要的但 jq 并且它是 JSON
超能力引起了我的兴趣,我想通过应用于现实世界的场景来学习它。这是一个...
顺便说一句,我试图利用现有的 jq 相关 SO 解决方案来合并/加入 JSON,但失败了。
我最接近我需要的是使用 INDEX 和 $x + 的串联。 ,但是我只从我的第二个 (c2) json
中获得了最后一个项目.
所以,我的问题如下:
有两个JSON
文件:
JSON
#1 将具有唯一的“id”和“type”键 - 在其他键/值对中,为了更好地清晰我的帖子,我已将其删除。JSON
#2 将包含多个/非唯一“类型”键,我想匹配这两个 JSON 文件。此 JSON
#2 还将包含其他键/值对,这些键/值对预计将包含在结果输出中。JSON
之间执行类似的匹配/连接会困难多少?文件一次 - 再次在特定键的相同值上?
JSON
#1,数组 c1(集合 1)
{ "c1":
[
{ "c1id":1, "type":"alpha" },
{ "c1id":2, "type":"beta" }
]
}
第二个输入文件:
JSON
#2,数组 c2(集合 2)
{
"c2":
[
{ "c2id":1,"type":"alpha","serial":"DDBB001"} ,
{ "c2id":2,"type":"beta","serial":"DDBB007"} ,
{ "c2id":3,"type":"alpha","serial":"DDTT005"} ,
{ "c2id":4,"type":"beta","serial":"DDAA002"} ,
{ "c2id":5,"type":"yotta","serial":"DDCC017"}
]
}
预期输出:
{"c1id":1,"type":"alpha","c2id":1,"serial":"DDBB001"}
{"c1id":1,"type":"alpha","c2id":3,"serial":"DDTT005"}
{"c1id":2,"type":"beta","c2id":2,"serial":"DDBB007"}
{"c1id":2,"type":"beta","c2id":4,"serial":"DDAA002"}
您会注意到 c2 中的类型“yotta”未包含在输出中。这是意料之中的。只有存在于 c1 中且匹配 c2 的“类型”才会出现在结果中。我想这是一个匹配/连接练习暗示了这一点 - 我添加它只是为了清楚起见 - 我希望它有效。
最佳答案
下面是一个使用 INDEX 和 JOIN 的例子:
jq --compact-output --slurpfile c1 c1.json '
INDEX(
$c1[0].c1[];
.type
) as $index |
JOIN(
$index;
.c2[];
.type;
reverse|add
)
' c2.json
INDEX 的第一个参数需要产生一个项目流,这就是我们应用
[]
的原因。分别从数组中获取项目。第二个参数选择我们的索引键。
[{"c2id":1,"type":"alpha","serial":"DDBB001"},{"c1id":1,"type":"alpha"}]
由于我们只想组合来自我们只使用的对象的所有键和值
add
,但我们先
reverse
数组在 c2 字段之前很好地排列 c1 字段。最终结果如您所愿:
{"c1id":1,"type":"alpha","c2id":1,"serial":"DDBB001"}
{"c1id":2,"type":"beta","c2id":2,"serial":"DDBB007"}
{"c1id":1,"type":"alpha","c2id":3,"serial":"DDTT005"}
{"c1id":2,"type":"beta","c2id":4,"serial":"DDAA002"}
关于json - jq 加入公共(public)键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69134020/
我在数组中有一系列 [timestamp, count] 对,我想使用 jq 计算每个时间戳的累积和。我怎么能那样做? 这里是一个示例数据集: [ [1431047957699, 1], [1
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我在数组中有一系列 [timestamp, count] 对,我想使用 jq 计算每个时间戳的累积和。我怎么能那样做? 这里是一个示例数据集: [ [1431047957699, 1], [1
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我很好奇是否有一种干净的方法可以将行号添加到 jq 的输出,同时仍然保留输出的颜色。我已经尝试从 jq 到 cat -n 的管道,但不幸的是,这删除了在遍历 JSON 树时有很大帮助的着色。 最佳答案
我有一些看起来像json数据: { "p": { "d": { "a" : { "r": "foo", "g": 1 },
我正在使用 jq 在大文件中搜索特定结果。我不关心与此特定条件匹配的重复条目,并且处理整个文件需要一段时间。我想做的是打印有关第一场比赛的一些详细信息,然后在文件上终止 jq 命令以节省时间。 IE。
给定以下 JSON 文件 foo.js(为清楚起见已删除): {"a":{"b":[{"x":{"x1":1},"y":{"y1":5}},{"x":{"x1":1},"y":{"y1":6}}]}}
我需要从一些 JSON 中一次删除多个键(使用 jq ),并且我正在尝试了解是否有比每次调用 map 和 del 更好的方法。这是我的输入数据: test.json [ { "label"
我正在使用 jq 来解析日志数据,偶尔日志包含格式错误的内容(无效的 json),当发生这种情况时,jq 会在此时中止处理。 有没有办法让 jq 继续处理它可以做的事情,同时通过 stderr 报告问
我无法理解以下示例中显示的 jq(版本 1.6)更新运算符的行为。 为什么示例 1 返回更新后的对象,而示例 2 和 3 返回空对象或错误结果? 例子之间的区别仅在于将字符串转换为数字的函数的调用顺序
给定 [3,4] [5,2] 我想制作: [5,2] [3,4] 我试过了,但失败了: echo '[3,4] [5,2]' | jq 'sort_by(.[1])' jq: error (at :1
我有一个要用 JQ 处理的 JSON 文件。它在另一个对象中有一个对象数组,带有一个我想用来填充新数组的键。 在我的实际用例中,它嵌套在许多其他的绒毛中,还有更多的数组,但将其作为此类事物的一个更简单
我有这个 jq筛选: some_command | jq -r '.elements[] | select(.state=="LIVE" and .group == "some_text" and .
我无法理解以下示例中显示的 jq(版本 1.6)更新运算符的行为。 为什么示例 1 返回更新后的对象,而示例 2 和 3 返回空对象或错误结果? 例子之间的区别仅在于将字符串转换为数字的函数的调用顺序
给定 [3,4] [5,2] 我想制作: [5,2] [3,4] 我试过了,但失败了: echo '[3,4] [5,2]' | jq 'sort_by(.[1])' jq: error (at :1
我刚刚发现 jq 并且非常喜欢它。一件事我发现自己做了很多事情,比如: result=$(jq --raw-output '.some | .filters // ""') if [[ $result
我一直在尝试使用 chocoletey 安装 jq 但是,当我运行以下命令时,它失败了。 choco install jq 阅读日志文件,我看到它指向 Powershell 脚本指向一个不再存在的 U
json block 数组中的数千个 json block 之一如下所示 - { "id": 4409976, "name": "MKLIU", "version": "1.0", "
json block 数组中的数千个 json block 之一如下所示 - { "id": 4409976, "name": "MKLIU", "version": "1.0", "
我是一名优秀的程序员,十分优秀!