JSON JQ if without else
You may want to use the idiom:
if CONDITION then WHATEVER else empty end
empty
is a filter that outputs nothing at all -- not even null, which is after all something (namely a JSON value). It's a bit like a black hole, only blacker -- it will consume whatever it's offered, but unlike a black hole, it does not even emit Hawking radiation.
In your case, you have an "elif" so using "else empty" is probably what you want, but for reference, the above is exactly equivalent to:
select(CONDITION) | WHATEVER
P.S. My guess is that whatever the goal of the sed command, it could be done more reliably as part of the jq program, perhaps using walk/1
.
UPDATE
After the release of jq 1.6, a change was made so that "if without else" has the semantics of "if _ then _ else . end", that is:
if P then Q end
=== if P then Q else . end
Since you're not making any further changes to the object, just use the "identity" filter .
.
if (.requests | length) then ... else . end
On the other hand, you're just updating the requests
or result
property if non-empty using map
. The check isn't necessary. If it's empty, then it will return empty.
You can simplify your filter to just:
.requests |= map(select(.id == \"123\")) | .result |= map(select(.id== \"123\"))