jq:解析并显示JSON中的多个值

问题描述

我有这个test.json文件

{
  "list": [
    {
      "expand": "xx","id": "xxxxx","self": "https","key": "test-11","fields": {
        "field_1": "1234"
      }
    },{
      "expand": "xx","key": "test-10","fields": {
        "field_1": "1235","field_2": null
      }
    }
  ]
}

我正在尝试使用IFS while循环读取值:

cat test.json| jq -r '[.list[]| ([.key]|tostring) + "," + "\(.fields| .field_1)"]|@tsv' \
| while IFS="," read -r key field_1; do
echo "$key $field_1"
curl -s https ://thisistest.com/api/$key/$field_1
done;
echo output displays only: test-11

我想获取keyfield_1的值,以便在curl请求中使用它们。

解决方法

@Kev中带有注释的jq命令将提取所需的值,每对每行,如下所示:

> jq -r '.list[]|[.key,.fields.field_1]|@tsv' test.json
test-11 1234
test-10 1235

您可以在此处修改脚本,以每个值对提出curl个请求。

#!/bin/bash
while read -r key field_1; do
    echo curl -s https://thisistest.com/api/$key/$field_1
done < <( jq -r '.list[]|[.key,.fields.field_1]|@tsv' test.json )

如果测试没问题,请删除echo

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...