首页 > 解决方案 > jq:从前 N 个元素中获取特定的重复键值

问题描述

我正在尝试解析https://api.weather.gov/gridpoints/PHI/47,91/forecast/hourly,并取得了一定的成功。

{
  "number": 1,
  "name": "",
  "startTime": "2020-12-16T13:00:00-05:00",
  "endTime": "2020-12-16T14:00:00-05:00",
  "isDaytime": true,
  "temperature": 30,
  "temperatureUnit": "F",
  "temperatureTrend": null,
  "windSpeed": "15 mph",
  "windDirection": "NE",
  "icon": "https://api.weather.gov/icons/land/day/snow,40?size=small",
  "shortForecast": "Chance Light Snow",
  "detailedForecast": ""
}

我开始jq '.properties.periods[0]'抓取第一个元素,使用它jq '.properties.periods[0].shortForecast',我发现这jq '.properties.periods[0,1,2,3]'让我得到了数组中的前 4 个元素。

但是,如果我尝试,我会遇到语法错误jq '.properties.periods[:3]'

jq:错误:语法错误,意外'['

我认为这将是 0-3 的简写。

此外,我只想要来自每个元素的(相同的、重复的)特定 K/V 对(例如:shortForecast、、temperature等),但我无法弄清楚如何将它们全部组合成一个jq语句。

那么如何从数组的第一个 X 元素中获取特定值呢?(我真的不需要键,只需要值。

奖励:将每个元素的所有值放在一行上会很棒。

样本:

"2020-12-16T14:00:00-05:00" 30 "Chance Light Snow"
"2020-12-16T15:00:00-05:00" 30 "Snow"
"2020-12-16T16:00:00-05:00" 29 "Heavy Snow"

标签: jsonjqkey-valueweather-api

解决方案


.properties.periods[:3]计算三个项目的数组,而.properties.periods[0,1,2]产生一个项目。所以后者的缩写是:

.properties.periods[:3][]

选择

有很多可能性,例如在一行上获取一组特定的键值对:

jq -c '.properties.periods[:3][]
       | {shortForecast, temperature}' input.json

仅将值选择为 CSV:

.properties.periods[:3][]
| {shortForecast, temperature}
| [.[]]
| @csv

您可能想@tsv改用 , or join(" "), or ....

奖金

要按给定顺序获取所有值,您可以简单地省略选择行:| {....}

但是,这不会那么健壮。以下会更安全:

.properties.periods[:3]
| (.[0] | keys_unsorted) as $keys
| .[]
| [.[$keys[]]]
| @tsv

推荐阅读