답변:
나는 이것에 갈 것이다.
패턴 뒤의 5 줄 삭제 (패턴이있는 줄 포함) :
sed -e '/pattern/,+5d' file.txt
패턴 뒤의 5 줄 삭제 (패턴이있는 줄 제외) :
sed -e '/pattern/{n;N;N;N;N;d}' file.txt
/pattern/,+5
범위를 정의합니다. 범위는 "패턴"( /pattern/
)을 포함하는 줄로 시작하고 5 줄 뒤에 끝납니다 ( +5
). 마지막 문자 d
는 해당 범위의 각 행에서 실행할 명령으로 "삭제"입니다. 두 번째 레시피에서는 범위를 일치시키는 대신 패턴 ( /pattern/
)을 포함하는 줄에서 일치 한 다음 일련의 명령을 실행합니다. {n;N;N;N;N;d}
, 기본적으로 다음 줄 ( n
)을 인쇄 한 다음 다음 4 줄을 읽고 마지막으로 삭제합니다 ( N;N;N;N;d
).
sed -e '/pattern/{n;N;N;N;N;d;}' file.txt
something
수행하십시오. sed -E '/^something$/,$d'
, 여기서는 -E
POSIX 이식성 확장 정규식입니다.
간단한 awk
솔루션 :
일치하는 줄을 찾는 데 사용할 정규식이 쉘 변수에 저장되고 $regex
건너 뛸 줄 수라고 가정합니다 $count
.
일치하는 줄 도 건너 뛰어야 하는 경우 ( $count + 1
줄 건너 뛰기) :
... | awk -v regex="$regex" -v count="$count" \
'$0 ~ regex { skip=count; next } --skip >= 0 { next } 1'
는 IF 일치하는 라인은해야 하지 건너 뛸 수 ( $count
선 후 경기는 건너 뜁니다) :
... | awk -v regex="$regex" -v count="$count" \
'$0 ~ regex { skip=count; print; next } --skip >= 0 { next } 1'
설명:
-v regex="$regex" -v count="$count"
같은 이름의 쉘 변수를 awk
기반으로 변수를 정의 합니다 .$0 ~ regex
관심 라인과 일치
{ skip=count; next }
건너 뛰기 횟수를 초기화하고 다음 줄로 진행하여 효과적으로 일치하는 줄을 건너 뜁니다. 두 번째 솔루션에서는 print
이전 next
이 건너 뛰지 않도록 합니다.--skip >= 0
건너 뛰기 횟수를 줄이고 (여전히)> = 0 인 경우 조치를 취합니다. 이는 당면한 줄을 건너 뛰어야 함을 의미합니다.{ next }
다음 줄로 진행하여 효과적으로 현재 줄을 건너 뜁니다.1
일반적으로 사용되는 속기입니다 { print }
. 즉, 현재 행이 단순히 인쇄됩니다.
1
에 해당되고 { print }
그는 인 1
정의로 항상 (블록) 연관된 동작이 무조건 실행되도록하는 수단은, 참으로 평가하는 부울 패턴으로 해석된다. 이 경우 연관된 조치 가 없으므로awk
기본적으로 행 을 인쇄 합니다.이것은 당신을 위해 일할 수 있습니다.
cat <<! >pattern_number.txt
> 5 3
> 10 1
> 15 5
> !
sed 's|\(\S*\) \(\S*\)|/\1/,+\2{//!d}|' pattern_number.txt |
sed -f - <(seq 21)
1
2
3
4
5
9
10
12
13
14
15
21
pattern_number.txt
첫 번째 열에서 일치시킬 패턴을 포함하고 두 번째 열에서 건너 뛸 행 수를 포함하는 2 열 파일입니다. 첫 번째 sed
명령은 파일을 sed
해당 일치 및 건너 뛰기를 수행 하는 스크립트 로 변환합니다 . 해당 스크립트는 -f
및 stdin ( -
)을 통해 두 번째 sed
명령에 제공됩니다. 두 번째 sed
명령은의 출력에서 형성된 샘플 임시 입력 파일에서 seq 21
작동하여 작동하는지 보여줍니다.
Perl 사용
$ cat delete_5lines.txt
1
2
3
4
5 hello
6
7
8
9
10
11 hai
$ perl -ne ' BEGIN{$y=1} $y=$. if /hello/ ; print if $y==1 or $.-$y > 5 ' delete_5lines.txt
1
2
3
4
11 hai
$
이 솔루션을 사용하면 "n"을 매개 변수로 전달할 수 있으며 파일에서 패턴을 읽습니다.
awk -v n=5 '
NR == FNR {pattern[$0]; next}
{
for (patt in pattern) {
if ($0 ~ patt) {
print # remove if you want to exclude a matched line
for (i=0; i<n; i++) getline
next
}
}
print
}
' file.with.patterns -
"-"라는 파일은 awk의 stdin을 의미하므로 파이프 라인에 적합합니다.
+N
패턴이 GNU 확장이다. 두 번째 예제에서 첫 번째n
를로 변경하여N
패턴이있는 선을 포함하도록합니다.