I'm trying to use jq to parse a NOAA data feed into just the values I need:
http://forecast.weather.gov/MapClick.php?FcstType=json&lat=39.56&lon=-104.85
I'm able to (separately) extract the two arrays I'm looking to combine:
$ cat noaa.json | jq .time.startPeriodName
[
"Today",
"Tonight",
"Friday",
"Friday Night",
"Saturday",
"Saturday Night",
"Sunday",
"Sunday Night",
"Monday",
"Monday Night",
"Tuesday",
"Tuesday Night",
"Wednesday"
]
$ cat noaa.json | jq .data.weather
[
"Mostly Sunny",
"Mostly Cloudy",
"Mostly Sunny",
"Partly Cloudy",
"Slight Chance Showers",
"Slight Chance Snow Showers",
"Slight Chance Snow Showers then Mostly Sunny",
"Mostly Clear",
"Mostly Sunny",
"Partly Cloudy",
"Mostly Sunny",
"Partly Cloudy",
"Mostly Sunny"
]
I'd like to combine the two arrays together into a single object like this:
{
"Today": "Mostly Sunny",
"Tonight": "Mostly Cloudy",
...
"Wednesday": "Mostly Sunny"
}
I'd be grateful if someone could point me in the right direction. I feel like the answer is probably in the map
operator, but I haven't been able to figure it out.
Yes, map
is a good way to go. The key here is to use it with transpose/0
, which can be used as though it were a "zip" function:
[.time.startPeriodName, .data.weather]
| transpose
| map( {(.[0]): .[1]})
The output begins as follows:
[
{
"Today": "Mostly Sunny"
},
{
"Tonight": "Mostly Cloudy"
},
...
So, to produce a single JSON object, simply add the add
filter to the pipeline.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With