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
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"
其他回答
下面是@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'
Echo '{"ab": 1, "cd": 2}' | jq -r 'keys[]'打印所有键每行一个键,不带引号。
ab
cd
你需要使用jq 'keys[]'。例如:
echo '{"example1" : 1, "example2" : 2, "example3" : 3}' | jq 'keys[]'
将输出一个行分隔的列表:
"example1"
"example2"
"example3"
获取JSON中更深层次节点上的键:
echo '{"data": "1", "user": { "name": 2, "phone": 3 } }' | jq '.user | keys[]'
"name"
"phone"
结合上面的答案,你想要jq的原始输出,所以你的最后一个过滤器应该是eg.:
cat input.json | jq -r 'keys'
来自jq帮助:
-r output raw strings, not JSON texts;