Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

jq: Cannot index array with string

Tags:

json

jq

I have the following in a file (which I will call "myfile"):

[{
    "id": 123,
    "name": "John",
    "aux": [{
        "abc": "random",
        "def": "I want this"
    }],
    "blah": 23.11
}]

I could parse it if the file did not have the first [ and last ] as follows:

$ cat myfile | jq -r '.aux[] | .def'
I want this
$

but with the [ and ] I get:

$ cat myfile | jq -r '.aux[] | .def'
jq: error: Cannot index array with string

How can I deal with the [ and ] using jq? (I'm sure I could parse them off with a different tool but I want to learn correct usage of jq.

like image 656
Xu Wang Avatar asked Dec 31 '15 09:12

Xu Wang


1 Answers

It should be:

jq '.[].aux[].def' file.json

.[] iterates over the outer array, .aux[] then iterates over the the aux array of every node and .def prints their .def property.

This will output:

"I want this"

If you want to get rid of the double quotes pass -r (--raw) to jq:

jq -r '.[].aux[].def' file.json

Output:

I want this
like image 72
hek2mgl Avatar answered Nov 14 '22 20:11

hek2mgl