다음 파일이 있습니다( ========
실제로 파일에 존재함).
start ======== id: 5713
start ======== id: 5911
start ======== id: 5911
end ========= id: 5911
start ======== id: 6111
end ========= id: 5713
start ======== id: 31117
start
동일한 ID 를 갖고 각각 end
.
위의 예를 기반으로 하면 출력은 다음과 같습니다.
start ======== id: 5911
start ======== id: 6111
start ======== id: 31117
bash
, awk
, ...로 sed
이 작업을 수행하는 방법은 무엇입니까 ?
답변1
모든 Unix 시스템의 모든 쉘에서 awk를 사용하면 입력에 있는 수만큼 짝이 없는 시작 및/또는 종료 문이 인쇄됩니다.
$ cat tst.awk
$1 == "start" { beg[$NF] = $0; delta = 1 }
$1 == "end" { end[$NF] = $0; delta = -1 }
{ cnt[$NF] += delta }
END {
for ( key in cnt ) {
for (i=1; i<=cnt[key]; i++) {
print beg[key]
}
for (i=-1; i>=cnt[key]; i--) {
print end[key]
}
}
}
$ awk -f tst.awk file
start ======== id: 5911
start ======== id: 6111
start ======== id: 31117
더 나은 시연을 위해 보다 포괄적인 예시 입력을 사용하세요.
$ cat file
start ======== id: 5713
start ======== id: 5911
start ======== id: 5911
start ======== id: 5911
end ========= id: 5911
start ======== id: 6111
end ========= id: 5713
end ========= id: 5713
start ======== id: 31117
$ awk -f tst.awk file
end ========= id: 5713
start ======== id: 5911
start ======== id: 5911
start ======== id: 6111
start ======== id: 31117
답변2
sed와 nl을 입력하고 정렬하세요.
nl <filename> -s ":"|sort -t ":" -k 3 -k 2 | sed -n ":x s/\n[0-9 ]*$//;/end[^\n]*$/{N;bx};s/\(.*\)[ 0-9]*:end .*id:\( [0-9]*\).*\n.*start.*id:\2[^0-9]*$/\1/;tx;s/\n$//;/start/{P;D};/^[ 0-9]*:end[^\n]*/{s/\n[0-9:]*$/$/;N;bx};/start/P;/end/P;" | sort -n| sed "s/[ 0-9]*://"
nl tt -s ":"|sort -t ":" -k 3 -k 2 | sed -n ":x s/\n[0-9 ]*$//;/end[^\n]*$/{N;bx};s/\(.*\)[ 0-9]*:end .*id:\( [0-9]*\).*\n.*start.*id:\2[^0-9]*$/\1/;tx;s/\n$//;/start/{P;D};/^[ 0-9]*:end[^\n]*/{s/\n[0-9:]*$/$/;N;bx};/start/P;/end/P;" | sort -n| sed "s/[ 0-9]*://"
start ======== id: 5713
start ======== id: 5713
start ======== id: 5713
start ======== id: 5713
start ======== id: 5911
start ======== id: 6111
end ======== id: 31117
순서가 중요하지 않은 경우(양 끝에 출발선이 있는 경우):
sort <filename> -t ":" -k 2|sed -e '/end/{N;d;}
start ======== id: 31117
start ======== id: 5911
start ======== id: 6111
이것이 더 좋습니다(수정이 필요하지만 작동합니다).
sort <filename> -t ":" -k 2 | sed -n ":x ;/end[^\n]*$/{N;bx};s/\(.*\)end .*id:\( [0-9]*\).*start.*id:\2[^0-9]*$/\1/;tx;s/\n$//;/start/{P;D};/^end[^\n]*/{s/\n$/$/;N;bx};/start/P;/end/P"
cat tt
start ======== id: 5713
start ======== id: 5713
start ======== id: 5713
start ======== id: 5713
start ======== id: 5713
start ======== id: 5713
start ======== id: 5713
dggdgtfZZ
start ======== id: 5713
start ======== id: 5713
start ======== id: 5911
start ======== id: 5911
end ========= id: 5911
start ======== id: 6111
end ========= id: 5713
end ========= id: 5713
end ========= id: 5713
end ========= id: 5713
end ========= id: 5713
start ======== id: 31117
end ======== id: 31117
end ======== id: 31117
sort -t ":" -k 2 tt| sed -n ":x ;/end[^\n]*$/{N;bx};s/\(.*\)end .*id:\( [0-9]*\).*start.*id:\2[^0-9]*$/\1/;tx;s/\n$//;/start/{P;D};/^end[^\n]*/{s/\n$/$/;N;bx};/start/P;/end/P"
end ======== id: 31117
start ======== id: 5713
start ======== id: 5713
start ======== id: 5713
start ======== id: 5713
start ======== id: 5911
start ======== id: 6111