linux工具之jq

简介

在linux下进行日常的开发时,我们经常需要对json格式的数据进行处理分析。jq是一个开源的JSON格式数据处理工具,它提供了很多灵活的语法,功能非常强大。

安装

  • macOS:
brew install jq
  • Ubuntu
apt-get install jq

jq语法

基础用法

假设文本test_json中有如下字符串

{
    "name":"xiaoming",
    "age":21,
    "birthday":"10th August",
    "email":"yj.xxxx@xxxx.com",
    "skills":[
        {
            "name":"C++",
            "level":2
        },
        {
            "name":"Python",
            "level":1
        }
    ]
}

通过key筛选

jq 表达式

cat test_json | jq ".name"

输出

"xiaoming"

通过index筛选

jq 表达式

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("|")筛选

jq表达式

cat test_json | jq ".skills[] | .level"

输出

2
1

构造数组Array

jq表达式

cat test_json | jq "[.age, .email]"

输出

[
  21,
  "yj.xxxx@xxxx.com"
]

构造Mapping

jq表达式

cat test_json | jq "{name, skills_2 : .skills}"

输出

{
  "name": "xiaoming",
  "skills_2": [
    {
      "name": "C++",
      "level": 2
    },
    {
      "name": "Python",
      "level": 1
    }
  ]
}

jq表达式

cat test_json | jq "{(.name): .skills}"

输出

{
  "xiaoming": [
    {
      "name": "C++",
      "level": 2
    },
    {
      "name": "Python",
      "level": 1
    }
  ]
}

内建操作符和函数

加法

jq表达式

cat test_json | jq ".age + 1"

输出

22

字符拼接

cat test_json | jq ".age + .name"

输出

"yj.xxxx@xxxx.comxiaoming"

减法 -

jq表达式

echo '["xml", "yaml", "json"]' | jq '. - ["xml", "yaml"]'

输出

[
  "json"
]

Length

jq表达式

echo '[[1,2], "string", {"a":2}, null]' | jq '[.[]| length]'

输出

[
  2,
  6,
  1,
  0
]

keys

jq表达式

cat test_json | jq 'keys'

输出

[
  "age",
  "birthday",
  "email",
  "name",
  "skills"
]

in

jq表达式

echo '["foo", "bar"]' | jq '.[] | in({"foo": 42})'

输出

true
false

map

jq表达式

echo '[1,2,3]' | jq 'map(.+1)'

输出

[
  2,
  3,
  4
]

map_values

jq表达式

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

jq表达式

echo '[{"id": "first", "val": 1}, {"id": "second", "val": 2}]' | jq '.[] | select(.id == "second")'

输出

{
  "id": "second",
  "val": 2
}

any

jq 表达式

echo '[true, false]' | jq 'any'

输出

true

all

jq表达式

echo '[true, false]' | jq 'all'

输出

false

min、max

jq表达式

echo '[5,4,2,7]' | jq 'min'

输出

2

sort、sort_by

jq表达式

echo '[8,3,null,6]' | jq 'sort'

输出

[
  null,
  3,
  6,
  8
]

jq表达式

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

jq表达式

echo '["a","b", "c"]' | jq 'index("b")'

输出

1

json

jq 表达式

echo '["a","b","c"]' | jq 'join(";")'

输出

"a;b;c"

条件判断

jq 表达式

echo 2 | jq 'if . == 0 then  "zero" elif . == 1 then "one" else  "many" end'

输出

"many"

参考

上一篇:KubeCon 速递 | 云原生操作系统进化,详解阿里云ACK Pro、ASM、ACR EE、ACK@Edge等四款企业级容器新品


下一篇:通过Kubernetes安全高效管理边缘节点,ACK@Edge年度重磅发布