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\"))