이 입력이 주어지면 :
[
{
"Id": "cb94e7a42732b598ad18a8f27454a886c1aa8bbba6167646d8f064cd86191e2b",
"Names": [
"condescending_jones",
"loving_hoover"
]
},
{
"Id": "186db739b7509eb0114a09e14bcd16bf637019860d23c4fc20e98cbe068b55aa",
"Names": [
"foo_data"
]
},
{
"Id": "a4b7e6f5752d8dcb906a5901f7ab82e403b9dff4eaaeebea767a04bac4aada19",
"Names": [
"jovial_wozniak"
]
},
{
"Id": "76b71c496556912012c20dc3cbd37a54a1f05bffad3d5e92466900a003fbb623",
"Names": [
"bar_data"
]
}
]
내부 배열 에 “데이터”를 포함 하지 않는 s를 가진 모든 객체를 반환 하는 jq 로 필터를 구성하려고 합니다. 출력은 줄 바꿈으로 구분됩니다. 위의 데이터의 경우 원하는 출력은Id
Names
cb94e7a42732b598ad18a8f27454a886c1aa8bbba6167646d8f064cd86191e2b
a4b7e6f5752d8dcb906a5901f7ab82e403b9dff4eaaeebea767a04bac4aada19
나는 이것과 다소 가깝다고 생각합니다.
(. - select(.Names[] contains("data"))) | .[] .Id
그러나 select
필터가 올바르지 않고 컴파일되지 않습니다 (get error: syntax error, unexpected IDENT
).
답변
아주 근접한! 당신에 select
표현, 당신은 파이프 (사용해야 |
하기 전에) contains
.
이 필터는 예상 출력을 생성합니다.
. - map(select(.Names[] | contains ("data"))) | .[] .Id
JQ 해설서는 구문의 일례가있다.
키의 내용을 기준으로 객체 필터링
예를 들어, 장르 키에 “house”가 포함 된 개체 만 원합니다.
$ json='[{"genre":"deep house"}, {"genre": "progressive house"}, {"genre": "dubstep"}]' $ echo "$json" | jq -c '.[] | select(.genre | contains("house"))' {"genre":"deep house"} {"genre":"progressive house"}
Colin D 는 배열의 JSON 구조를 유지하는 방법을 묻습니다. 따라서 최종 출력은 JSON 개체 스트림이 아닌 단일 JSON 배열입니다.
가장 간단한 방법은 전체 표현식을 배열 생성자로 감싸는 것입니다.
$ echo "$json" | jq -c '[ .[] | select( .genre | contains("house")) ]'
[{"genre":"deep house"},{"genre":"progressive house"}]
지도 기능을 사용할 수도 있습니다.
$ echo "$json" | jq -c 'map(select(.genre | contains("house")))'
[{"genre":"deep house"},{"genre":"progressive house"}]
map은 입력 배열의 압축을 풀고 모든 요소에 필터를 적용하고 새 배열을 만듭니다. 즉, map(f)
와 같습니다 [.[]|f]
.