首页 > 解决方案 > 使用jq获取json值

问题描述

输入json:

{
"food_group": "fruit",
"glycemic_index": "low",
    "fruits": {
        "fruit_name": "apple",
        "size": "large",
        "color": "red"
    }
}

以下两个 jq 命令起作用:

# jq -r 'keys_unsorted[] as $key | "\($key), \(.[$key])"' food.json
food_group, fruit
glycemic_index, low
fruits, {"fruit_name":"apple","size":"large","color":"red"}

# jq -r 'keys_unsorted[0:2] as $key | "\($key)"' food.json
["food_group","glycemic_index"]

如何以相同的方式使用 jq 获取前两个键的值?我在下面试过

# jq -r 'keys_unsorted[0:2] as $key | "\($key), \(.[$key])"' food.json
jq: error (at food.json:9): Cannot index object with array

预期输出:

food_group, fruit
glycemic_index, low

标签: jsonjq

解决方案


要遍历散列数组,您可以使用to_entries并将转换为数组。

之后您可以使用select来过滤您想要保留的行。

 jq -r 'to_entries[]| select(  ( .value | type ) == "string" ) | "\(.key), \(.value)" ' 

推荐阅读