31

input json:

{
  "id": "3885",
  "login": "050111",
  "lastLoginTime": 1529730115000,
  "lastLoginFrom": "192.168.66.230"
}
{
  "id": "3898",
  "login": "050112",
  "lastLoginTime": null,
  "lastLoginFrom": null
}

I want to get output for login, lastLoginTime and lastLoginFrom in tabulator delimited format:

050111  1529730115000   192.168.66.230
050112              -                -

with below jq filter I get on output no "null" values which I could replace with "-"

$ jq -r '.|[.login, .lastLoginTime, .lastLoginFrom]|@tsv' test_json
050111  1529730115000   192.168.66.230
050112

Is there any other way to get "-" printed for such null values?

2 Answers 2

59

use the alternative operator: //

so :

$jq -r '.|[.login, .lastLoginTime // "-" , .lastLoginFrom // "-" ]|@tsv' test_json
050111  1529730115000   192.168.66.230
050112  -   -
1
  • 7
    The initial .| is not needed. Commented Jun 23, 2018 at 16:30
2

This is using the same actual feature of jq to change the null values into dashes as EchoMike444 in their answer, but doing it in another way.

Instead of listing the keys to extract, I delete the id key that we don't want to use. I then extract the remaining values and use map() to change the values that are null into dashes:

$ jq -r '[del(.id)[]] | map(.//"-") | @tsv' file
050111  1529730115000   192.168.66.230
050112  -       -

Using Miller (mlr) to read the JSON input and change all fields that are null to -. We then exclude the id field and output what's left as TSV.

$ mlr --ijson --otsv --headerless-csv-output put 'for (k,v in $*) { is_null(v) { $[k] = "-" } }' then  cut -x -f id file
050111  1529730115000   192.168.66.230
050112  -       -
1
  • I also adds, that in complex expressions parenthesis are needed ((.lastLoginTime // "-")) Commented Nov 19, 2022 at 17:11

You must log in to answer this question.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.