jq - 밀리초 변환

jq - 밀리초 변환

JSON을 입력하세요:

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

필터는 Lastlogintime이 존재할 때 작동합니다.

$ jq -jr --arg ARG1 050111 'select(.login==$ARG1)|"user:", " ",.login,"\n","lastlogintime:", " ",(.lastLoginTime / 1000 | strftime("%Y-%m-%d %H:%M UTC")),"\n","lastloginfrom:", " ",.lastLoginFrom // "-","\n"' test_json3
user: 050111
lastlogintime: 2018-06-23 05:01 UTC
lastloginfrom: 192.168.66.230

그러나 lastlogintime이 없으면 문제가 발생합니다("-"가 인쇄되지 않음).

$ jq -jr --arg ARG1 050112 'select(.login==$ARG1)|"user:", " ",.login,"\n","lastlogintime:", " ",(.lastLoginTime / 1000 | strftime("%Y-%m-%d %H:%M UTC")),"\n","lastloginfrom:", " ",.lastLoginFrom // "-","\n"' test_json3
user: 050112
jq: error (at test_json3:12): null (null) and number (1000) cannot be divided

마지막 로그인 시간이 비어 있을 때 분할 작업을 건너뛰는 방법은 무엇입니까?

답변1

jq -r --arg ARG1 050112 'select(.login == $ARG1)|
    ["user:", .login],
    ["lastlogintime:", if .lastLoginTime then (.lastLoginTime/1000 | strftime("%Y-%m-%d %H:%M UTC")) else "-" end],
    ["lastloginfrom:", .lastLoginFrom // "-"]
    |@tsv' file.json

즉, 정의되거나 정의되지 않은 시기를 나타내기 위해 명시적인 if- then-를 사용합니다.elselastLoginTime

관련 정보