Curl http://testhost.test.com:8080/application/app/version | jq '。版本' | jq '.[]'

上面的命令只输出如下值:

"madireddy@test.com"

"2323"

"test"

"02-03-2014-13:41"

"application"

我怎样才能得到像下面这样的键名:

email

versionID

context

date

versionName

当前回答

将一行中的键打印为csv格式:

echo '{"b":"2","a":"1"}' | jq -r 'keys | [ .[] | tostring ] | @csv'

输出:

"a","b"

为了csv的完整性…将一行中的值打印为csv格式:

echo '{"b":"2","a":"1"}' | jq -rS . | jq -r '. | [ .[] | tostring ] | @csv'

输出:

"1","2"

其他回答

如果你的输入是一个对象数组,

[
  { 
    "a01" : { "name" : "A", "user" : "B" }
  },
  { 
    "a02" : { "name" : "C", "user" : "D" }
  }
]

试一试:

jq '.[] | keys[]'

结合上面的答案,你想要jq的原始输出,所以你的最后一个过滤器应该是eg.:

     cat input.json | jq -r 'keys'

来自jq帮助:

     -r     output raw strings, not JSON texts;

下面是@anubhava在他的回答中给出的JSON示例获得Bash数组的另一种方式:

arr=($(jq --raw-output 'keys_unsorted | @sh' file.json))

echo ${arr[0]}    # 'Archiver-Version'
echo ${arr[1]}    # 'Build-Id'
echo ${arr[2]}    # 'Build-Jdk'

将一行中的键打印为csv格式:

echo '{"b":"2","a":"1"}' | jq -r 'keys | [ .[] | tostring ] | @csv'

输出:

"a","b"

为了csv的完整性…将一行中的值打印为csv格式:

echo '{"b":"2","a":"1"}' | jq -rS . | jq -r '. | [ .[] | tostring ] | @csv'

输出:

"1","2"

获取JSON中更深层次节点上的键:

echo '{"data": "1", "user": { "name": 2, "phone": 3 } }' | jq '.user | keys[]'
"name"
"phone"