获取jq json解析中的第一个(或第n个)元素

时间:2016-07-21 09:32:01

标签: json jq

我可以在[]

中的json中获取第一个元素
$ echo '[{"a":"x", "b":true}, {"a":"XML", "b":false}]' | jq '.[1]'
{
  "a": "XML",
  "b": false
}

但是如果json已经被反汇编(例如,在使用'select'过滤条目后),我如何选择单个条目并避免在此处看到错误?

$ echo '[{"a":"x", "b":true}, {"a":"x", "b":false},{"a":"XML", "b":false}]' | jq '.[] | select( .a == "x")'
{
  "a": "x",
  "b": true
}
{
  "a": "x",
  "b": false
}
$ echo '[{"a":"x", "b":true}, {"a":"x", "b":false},{"a":"XML", "b":false}]' | jq '.[] | select( .a == "x") | .[1]'
jq: error (at <stdin>:1): Cannot index object with number

4 个答案:

答案 0 :(得分:20)

您可以将select的结果包装在数组中:

jq '[.[]|select(.a=="x")][1]' your.json

输出:

{
  "a": "x",
  "b": false
}

答案 1 :(得分:5)

jq还提供first/0last/0nth/1所以在这种情况下过滤器

  ( map(select(.a == "x")) | first  )
, ( map(select(.a == "x")) | last   ) 
, ( map(select(.a == "x")) | nth(1) )

产生

{
  "a": "x",
  "b": true
}
{
  "a": "x",
  "b": false
}
{
  "a": "x",
  "b": false
}

其他流式表单'first/1''last/1''nth/2'也可以使用此数据

  ( first(.[]  | select(.a == "x")) )   
, ( last(.[]   | select(.a == "x")) )
, ( nth(1; .[] | select(.a == "x")) )

产生

{
  "a": "x",
  "b": true
}
{
  "a": "x",
  "b": false
}
{
  "a": "x",
  "b": false
}

答案 2 :(得分:2)

我认为以前的所有答案都没有抓住要点。要从独立对象流中选择单个条目,您真正需要做的就是使用 --slurp 选项(或简称 -s):

<块引用>
   o   --slurp/-s:

       Instead of running the filter for each JSON object in the input, read 
       the entire input stream into a large array and run the filter just once.

然后你就可以索引到数组中了。例如,要获取第二项(索引为 1):

jq --slurp '.[1]'

将其与您想要从流中选择该项目的原始问题放在一起:

echo '{"a":"x", "b":true} {"a":"XML", "b":false}' | jq --slurp '.[1]'

导致此输出:

{
  "a": "XML",
  "b": false
}

答案 3 :(得分:1)

使用map

cat raw.json|jq -r -c 'map(select(.a=="x"))|.[1]'

map重新启动过滤器来过滤数组。

这个命令

cat raw.json|jq -r -c 'map(select(.a=="x"))'

给出中间结果

[{"a":"x","b":true},{"a":"x","b":false}]

.[1]取第一个元素