我已经在这个问题上苦思冥想了几个小时,但似乎找不到解决的办法。我有一个键数组和一个值数组,如何生成一个对象呢?输入:
[["key1", "key2"], ["val1", "val2"]]
输出:
{"key1": "val1", "key2": "val2"}
在github上已解决此问题:
.[0] as $keys |
.[1] as $values |
reduce range(0; $keys|length) as $i ( {}; . + { ($keys[$i]): $values[$i] })
当前版本的jq有一个transpose
过滤器,可用于配对键和值。您可以使用它轻松构建结果对象。
transpose | reduce .[] as $pair ({}; .[$pair[0]] = $pair[1])
明确一点:
(0) Abdullah Jibaly的解决方案简单、直接、高效和通用,应该适用于所有版本的jq;
(1) transpose/0是在jq 1.5中内置的,并且自2014年10月以来已经在预发布版中提供;
(2) 使用transpose/0(或如上定义的zip/0),问题的解决方案更加简短、快速和通用。
transpose | map( {(.[0]): .[1]} ) | add
例子:
$ jq 'transpose | map( {(.[0]): .[1]} ) | add'
输入:
[["k1","k2","k3"], [1,2,3] ]
输出:
{
"k1": 1,
"k2": 2,
"k3": 3
}
放弃这个方法,对于长度大于2的数组实际上并不起作用。
[map(.[0]) , map(.[1])] | map({(.[0]):.[1]}) | add
我以为这很容易,因为我有一点Prolog的经验...哦天啊。最后我也撞了墙头。我想我以后不会再使用jq了。
zip
,那就不会太糟糕了。幸运的是,实现起来也不会太麻烦。 - Jeff Mercado这是一个使用reduce的解决方案,其中状态对象保存迭代索引和结果对象。它遍历.[0]
中的键,并从.[1]
设置相应的结果值
.[1] as $v
| reduce .[0][] as $k (
{idx:0, result:{}}; .result[$k] = $v[.idx] | .idx += 1
)
| .result
{ "key1": "val2", "key2": "val2" }
- Abdullah Jibaly