Linux 시스템의 grep 명령은 정규식을 사용하여 텍스트를 검색하고 일치하는 줄을 인쇄할 수 있는 강력한 텍스트 검색 도구입니다. grep의 전체 이름은 Global Regular Expression Print이며, 이는 전역 정규식 버전이 모든 사용자에게 적용된다는 의미입니다.
1. 기능
Linux 시스템의 grep 명령은 정규식을 사용하여 텍스트를 검색하고 일치하는 줄을 인쇄할 수 있는 강력한 텍스트 검색 도구입니다. grep의 전체 이름은 Global Regular Expression Print이며, 이는 전역 정규식 버전이 모든 사용자에게 적용된다는 의미입니다.
grep 제품군에는 grep, egrep 및 fgrep이 포함됩니다. egrep 및 fgrep 명령은 grep과 약간만 다릅니다. egrep은 더 많은 메타 문자를 지원하는 grep의 확장입니다. fgrep은 모든 문자를 단어로 처리하는 고정 grep입니다. 즉, 정규 표현식의 메타 문자는 더 이상 특별하지 않은 문자 그대로의 의미를 나타냅니다. Linux는 GNU 버전의 grep을 사용합니다. 더욱 강력하며 -G, -E 및 -F 명령줄 옵션을 통해 egrep 및 fgrep 기능을 사용할 수 있습니다.
2. 형식 및 주요 매개변수
grep [옵션]
주요 매개변수: grep --help를 볼 수 있습니다.
-c: 일치하는 라인의 개수만 출력합니다.
-i: 대소문자를 구분하지 않습니다.
-h: 여러 파일을 쿼리할 때 파일 이름을 표시하지 않습니다.
-l: 여러 파일을 쿼리할 때 일치하는 문자가 포함된 파일 이름만 출력됩니다.
-n: 일치하는 줄과 줄 번호를 표시합니다.
-s: 존재하지 않거나 일치하는 텍스트가 없는 오류 메시지를 표시하지 않습니다.
-v: 일치하는 텍스트가 포함되지 않은 모든 줄을 표시합니다. -COLOR = 자동: 검색된 키워드에 컬러 표시를 추가할 수 있습니다.
패턴 정규식의 주요 매개변수:
: 정규식에서 특수 문자의 원래 의미를 무시합니다.
^: 정규식의 시작 줄과 일치합니다.
$: 정규 표현식의 끝 줄과 일치합니다.
<: 정규식과 일치하는 줄부터 시작합니다.
>: 정규식과 일치하는 줄의 끝까지.
[ ]: [A]와 같은 단일 문자는 A가 요구 사항을 충족함을 의미합니다.
[-]: [A-Z]와 같은 범위, 즉 A, B, C ~ Z가 모두 요구 사항을 충족합니다.
.: 모두 단일 문자입니다.
*: 모든 문자, 길이는 0일 수 있습니다.
3. grep 명령 사용의 간단한 예
itcast$ grep 'test' d*
d로 시작하는 모든 파일에서 test가 포함된 행을 표시합니다.
aa, bb, cc 파일 라인 매칭 테스트.
각각 5개 이상의 연속된 소문자가 포함된 문자열을 포함하는 모든 줄을 표시합니다.
itcast $ grep 'w(es)t.*1′ aa
west가 일치하면 es는 메모리에 저장되고 1로 표시된 다음 임의 개수의 문자(.*)를 검색한 다음 다른 es(1 ), 발견되면 해당 행이 표시됩니다. egrep 또는 grep -E를 사용하는 경우 "" 기호로 이스케이프할 필요가 없으며 'w(es)t.*1'로 직접 작성하면 됩니다.
4. grep 명령은 복잡한 인스턴스를 사용합니다.
명시적으로 하위 디렉터리 검색을 요청합니다.
grep -r
또는 하위 디렉터리를 무시합니다.
grep -d 건너뛰기
출력이 많으면 읽기 위해 'less'로 파이프할 수 있습니다.
itcast$ grep Magic /usr/src/Linux/Documentation/* | less
이렇게 하면 더 편리하게 읽을 수 있습니다.
한 가지 주의할 점은 파일 필터링 방법을 제공해야 한다는 것입니다(모든 파일을 검색하려면 * 사용). 잊어버린 경우 'grep'은 프로그램이 중단될 때까지 기다립니다. 이 문제가 발생하면 를 누르고 다시 시도하세요.
아래에는 몇 가지 흥미로운 명령줄 매개변수가 있습니다.
grep -i 패턴 파일: 대소문자를 구분하지 않고 검색합니다. 기본값은 대소문자를 구분합니다.
grep -l 패턴 파일: 일치하는 파일 이름만 나열됩니다.
grep -L 패턴 파일: 일치하지 않는 파일 이름이 나열됩니다.
grep -w 패턴 파일: 전체 단어만 일치하고 일부는 일치하지 않습니다. 문자열(예: 'magic'이 아닌 'magic' 일치),
grep -C 숫자 패턴 파일: 일치하는 컨텍스트는 각각 [number] 줄을 표시합니다.
grep Pattern1 | Pattern2 파일: Pattern1 또는 Pattern2 와 일치하는 줄을 표시합니다.
예: grep "abc|xyz" testfile은 abc 또는 xyz를 포함하는 행 필터링을 의미합니다.
grep Pattern1 files | grep Pattern2: 패턴1과 패턴2 모두와 일치하는 행을 표시합니다.
grep -n 패턴 파일은 줄 번호 정보를 표시할 수 있습니다.
grep -c 패턴 파일은 총 줄 수를 찾을 수 있습니다.
검색에 사용되는 몇 가지 특수 기호도 있습니다. 각각 단어의 시작과 끝을 표시합니다.
예:
grep man *은 'Batman', 'manic', 'man' 등과 일치합니다.
grep '
'^': 일치하는 문자열이 줄의 시작 부분에 있음을 의미합니다.
'$': 일치하는 문자열이 줄의 끝에 있음을 의미합니다.
grep을 사용하여 구조를 찾습니다. grep -R "struct task_struct {" /usr/src plus -n 줄 번호 표시 가능
PS1=$ .bashrc에 홈 디렉터리 입력
[추천 과정: Linux 비디오 튜토리얼]
위 내용은 Linux의 grep 명령 전체 목록의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!