簡介
在linux下進行日常的開發時,我們經常需要對json格式的資料進行處理分析。
jq是一個開源的JSON格式資料處理工具,它提供了很多靈活的文法,功能非常強大。
安裝
- macOS:
brew install jq
- Ubuntu
apt-get install jq
- 其他參考 官網
jq文法
基礎用法
假設文本test_json中有如下字元串
{
"name":"xiaoming",
"age":21,
"birthday":"10th August",
"email":"[email protected]",
"skills":[
{
"name":"C++",
"level":2
},
{
"name":"Python",
"level":1
}
]
}
通過key篩選
jq 表達式
cat test_json | jq ".name"
輸出
"xiaoming"
通過index篩選
cat test_json | jq ".skills[0]"
{
"name": "C++",
"level": 2
}
周遊數組
jq表達式
cat test_json | jq ".skills[]"
{
"name": "C++",
"level": 2
}
{
"name": "Python",
"level": 1
}
通過Pipe("|")篩選
cat test_json | jq ".skills[] | .level"
2
1
構造數組Array
cat test_json | jq "[.age, .email]"
[
21,
"[email protected]"
]
構造Mapping
cat test_json | jq "{name, skills_2 : .skills}"
{
"name": "xiaoming",
"skills_2": [
{
"name": "C++",
"level": 2
},
{
"name": "Python",
"level": 1
}
]
}
cat test_json | jq "{(.name): .skills}"
{
"xiaoming": [
{
"name": "C++",
"level": 2
},
{
"name": "Python",
"level": 1
}
]
}
内建操作符和函數
加法
cat test_json | jq ".age + 1"
22
字元拼接
cat test_json | jq ".age + .name"
"[email protected]"
減法 -
echo '["xml", "yaml", "json"]' | jq '. - ["xml", "yaml"]'
[
"json"
]
Length
echo '[[1,2], "string", {"a":2}, null]' | jq '[.[]| length]'
[
2,
6,
1,
0
]
keys
cat test_json | jq 'keys'
[
"age",
"birthday",
"email",
"name",
"skills"
]
in
echo '["foo", "bar"]' | jq '.[] | in({"foo": 42})'
true
false
map
echo '[1,2,3]' | jq 'map(.+1)'
[
2,
3,
4
]
map_values
echo '{"a": 1, "b": 2, "c": 3}' | jq 'map_values(.+1)'
{
"a": 2,
"b": 3,
"c": 4
}
del
js表達式
echo '{"foo": 42, "bar": 9001, "baz": 42}' | jq "del(.foo)"
{
"bar": 9001,
"baz": 42
}
select
echo '[{"id": "first", "val": 1}, {"id": "second", "val": 2}]' | jq '.[] | select(.id == "second")'
{
"id": "second",
"val": 2
}
any
echo '[true, false]' | jq 'any'
true
all
echo '[true, false]' | jq 'all'
false
min、max
echo '[5,4,2,7]' | jq 'min'
2
sort、sort_by
echo '[8,3,null,6]' | jq 'sort'
[
null,
3,
6,
8
]
echo '[{"foo":4, "bar":10}, {"foo":3, "bar":100}, {"foo":2, "bar":1}]' | jq 'sort_by(.foo)'
[
{
"foo": 2,
"bar": 1
},
{
"foo": 3,
"bar": 100
},
{
"foo": 4,
"bar": 10
}
]
index
echo '["a","b", "c"]' | jq 'index("b")'
1
json
echo '["a","b","c"]' | jq 'join(";")'
"a;b;c"
條件判斷
echo 2 | jq 'if . == 0 then "zero" elif . == 1 then "one" else "many" end'
"many"