
이전 레코드의 마지막 문자와 현재 레코드의 첫 번째 문자를 기준으로 현재 레코드를 삭제하는 방법은 무엇입니까?
예:
abcd|efg
"xyz"|"ghi"
"lmn"|"qrs"
123|abc
요구 사항은 이전 레코드가 큰따옴표로 끝나고 현재 레코드가 큰따옴표로 시작하지 않는 레코드를 삭제하는 것입니다. 위의 예에서는 4번째 레코드를 출력에서 삭제해야 합니다.
답변1
$ awk '(prev !~ /"$/) || ($1 ~ /^"/){print} {prev=$1}' file
abcd|efg
"xyz"|"ghi"
"lmn"|"qrs"
또는 다음 중 하나를 선호하는 경우:
$ awk '!( (prev ~ /"$/) && ($1 !~ /^"/) ){print} {prev=$1}' file
abcd|efg
"xyz"|"ghi"
"lmn"|"qrs"
$ awk '{f=((prev ~ /"$/) && ($1 !~ /^"/)); prev=$1} !f' file
abcd|efg
"xyz"|"ghi"
"lmn"|"qrs"