변수 "nt"(슬래시 포함)를 검색해야 합니다. 파일 text1에서 해당 내용을 포함하는 모든 줄을 삭제합니다.
$ echo $nt
/u01/app/us1fa01_0/
$ cat text1
/u01/app/fa01/
/u01/app/us1fa01_0/
/u01/app/us1fa01_ps6/
예상 출력 -
$ cat text1
/u01/app/fa01/
/u01/app/us1fa01_ps6/
다음 명령을 시도했습니다.
sed "/$nt/d" text1
sed: -e expression #1, char 3: unknown command: `u'
sed "|$nt|d" text1
sed: -e expression #1, char 1: unknown command: `|'
sed '\|"$nt"|d' text1
/u01/app/fa01/ /u01/app/us1fa01_0/ /u01/app/us1fa01_ps6/
위의 코드 중 어느 것도 작동하지 않는 것 같습니다. 탈출구를 찾고
답변1
그리고grep:
grep -Fv -f <(echo "$nt") text1
-F
- 패턴을 고정된 문자열 목록으로 해석-v
- 일치하지 않는 행을 선택하기 위해 일치의 의미를 반전시킵니다.-f
- 파일에서 패턴을 한 줄에 하나씩 가져옵니다.
산출:
/u01/app/fa01/
/u01/app/us1fa01_ps6/
답변2
GNU sed를 사용하면 (다른 sed 구현에 대해서는 잘 모르겠습니다) 를 사용할 수 있습니다. 여기서 문자는 무엇이든 됩니다 \%pattern%
.%
따라서 다음이 작동합니다.
sed "\%$nt%d" text1
답변3
$ sed "\#$nt#d" text1
/u01/app/fa01/
/u01/app/us1fa01_ps6/
sed
로 인용하면 어떤 패턴 구분 기호라도 사용할 수 있습니다 \
.
이것은 것이다실패하다$nt
문자 가 포함된 경우 #
. 이 경우 다른 구분 기호를 사용하십시오.
이렇게 하면 해당 줄의 어느 위치에서든 패턴이 포함된 모든 줄이 삭제됩니다.
패턴이 전체 라인과 일치하도록 강제하려면 다음을 사용하십시오.
$ sed "\#^$nt\$#d" text1
$
여기서는 쉘에서 줄 끝 앵커를 참조해야 합니다 \$
.