Ответ 1
Вы можете использовать select-expression в jq
, чтобы сделать то, что вы намереваетесь достичь, что-то как
jq '.result | select(.property_history != null) | .property_history | map(select(.event_name == "Sold"))[0].date'
"08/30/2004"
Я получаю Cannot iterate over null (null)
из нижеследующего запроса, потому что .property_history
отсутствует в объекте result
.
Как проверить наличие клавиши .property_history
перед продолжением map(...)
?
Я попытался использовать что-то вроде sold_year= `echo "$content" | jq 'if has("property_history") then
map(select(.event_name == "Sold"))[0].date' else null end
Исходный запрос:
sold_year=`echo "$content" | jq '.result.property_history | map(select(.event_name == "Sold"))[0].date'`
JSON:
{
"result":{
"property_history":[
{
"date":"01/27/2016",
"price_changed":0,
"price":899750,
"event_name":"Listed",
"sqft":0
},
{
"date":"12/15/2015",
"price_changed":0,
"price":899750,
"event_name":"Listed",
"sqft":2357
},
{
"date":"08/30/2004",
"price_changed":0,
"price":739000,
"event_name":"Sold",
"sqft":2357
}
]
}
}
Вы можете использовать select-expression в jq
, чтобы сделать то, что вы намереваетесь достичь, что-то как
jq '.result | select(.property_history != null) | .property_history | map(select(.event_name == "Sold"))[0].date'
"08/30/2004"
Вы можете использовать оператор ?
post-fix:
$ jq '.result | .property_history? | .[] | select(.event_name == "Sold") | .date'
"08/30/2004"