Linux 命令行 jq 让你更优雅的处理 json 数据

Linux 命令行 jq 让你更优雅的处理 json 数据_第1张图片

https://github.com/stedolan/jq

https://stedolan.github.io/jq/manual/

brew install jq

data.json

$ cat data.json 
{
  "code": 0,
  "msg": "",
  "data": {
    "pageNo": 1,
    "pageSize": 10,
    "total": 5,
    "list": [
      {
        "id": null,
        "city": "北京",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "上海",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "广州",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "深圳",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "杭州",
        "name": null,
        "email": null
      }
    ]
  }
}
$ cat data.json | jq .
{
  "code": 0,
  "msg": "",
  "data": {
    "pageNo": 1,
    "pageSize": 10,
    "total": 5,
    "list": [
      {
        "id": null,
        "city": "北京",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "上海",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "广州",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "深圳",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "杭州",
        "name": null,
        "email": null
      }
    ]
  }
}
cat data.json | jq .code
0

列表中的单个

$ cat data.json | jq .data.list[0]
{
  "id": null,
  "city": "北京",
  "name": null,
  "email": null
}

列表中的多个

$ cat data.json | jq .data.list[0,1]
{
  "id": null,
  "city": "北京",
  "name": null,
  "email": null
}
{
  "id": null,
  "city": "上海",
  "name": null,
  "email": null
}

列表的全部

$ cat data.json | jq .data.list[]
{
  "id": null,
  "city": "北京",
  "name": null,
  "email": null
}
{
  "id": null,
  "city": "上海",
  "name": null,
  "email": null
}
{
  "id": null,
  "city": "广州",
  "name": null,
  "email": null
}
{
  "id": null,
  "city": "深圳",
  "name": null,
  "email": null
}
{
  "id": null,
  "city": "杭州",
  "name": null,
  "email": null
}

列表内的指定字段

$ cat data.json | jq .data.list[].city
"北京"
"上海"
"广州"
"深圳"
"杭州"

列表内的指定字段并删除双引号

$ cat data.json | jq .data.list[].city | tr -d '\"'
北京
上海
广州
深圳
杭州

删除单个属性

$ cat data.json | jq 'del(.msg)'
{
  "code": 0,
  "data": {
    "pageNo": 1,
    "pageSize": 10,
    "total": 5,
    "list": [
      {
        "id": null,
        "city": "北京",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "上海",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "广州",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "深圳",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "杭州",
        "name": null,
        "email": null
      }
    ]
  }
}

删除多个属性

$ cat data.json | jq 'del(.msg,.data.pageNo,.data.pageSize)'
{
  "code": 0,
  "data": {
    "total": 5,
    "list": [
      {
        "id": null,
        "city": "北京",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "上海",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "广州",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "深圳",
        "name": null,
        "email": null
      },
      {
        "id": null,
        "city": "杭州",
        "name": null,
        "email": null
      }
    ]
  }
}

删除列表内的属性

$ cat data.json | jq 'del(.msg,.data.pageNo,.data.pageSize,.data.list[].id)'
{
  "code": 0,
  "data": {
    "total": 5,
    "list": [
      {
        "city": "北京",
        "name": null,
        "email": null
      },
      {
        "city": "上海",
        "name": null,
        "email": null
      },
      {
        "city": "广州",
        "name": null,
        "email": null
      },
      {
        "city": "深圳",
        "name": null,
        "email": null
      },
      {
        "city": "杭州",
        "name": null,
        "email": null
      }
    ]
  }
}

把全部的杭州替换成成都

$ cat data.json | jq 'del(.msg,.data.pageNo,.data.pageSize,.data.list[].id)' | sed 's/杭州/成都/g'
{
  "code": 0,
  "data": {
    "total": 5,
    "list": [
      {
        "city": "北京",
        "name": null,
        "email": null
      },
      {
        "city": "上海",
        "name": null,
        "email": null
      },
      {
        "city": "广州",
        "name": null,
        "email": null
      },
      {
        "city": "深圳",
        "name": null,
        "email": null
      },
      {
        "city": "成都",
        "name": null,
        "email": null
      }
    ]
  }
}

更多 jq 相关 https://blog.csdn.net/wzj_110/article/details/117387891

你可能感兴趣的:(程序员必备软件,json)