Linux grep 및 정규식에 대한 간략한 소개

巴扎黑
풀어 주다: 2017-09-21 11:47:03
원래의
1896명이 탐색했습니다.

grep은 정규식을 사용하여 텍스트를 검색하고 일치하는 줄을 인쇄하는 강력한 텍스트 검색 도구입니다. 이 기사를 통해 Linux grep 및 정규식에 대한 지식을 공유하겠습니다. 관심 있는 친구들은 함께 살펴보세요

grep 소개

Grep은 정규식을 사용할 수 있는 강력한 텍스트 검색 도구입니다. 텍스트를 입력하고 일치하는 줄을 인쇄합니다. 일반적으로 grep에는 grep, egrep(grep -E와 동일) 및 fgrep의 세 가지 버전이 있습니다. egrep은 확장 grep이고 fgrep은 빠른 grep입니다(검색 텍스트에 대한 고정 문자열, 정규식 참조를 지원하지 않지만 쿼리는 매우 빠릅니다). grep은 Linux 텍스트 처리의 삼총사 중 하나입니다.

grep 사용 방법

사용 방법:


grep [OPTIONS] PATTERN [FILE...]
로그인 후 복사


grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
로그인 후 복사

일반 옵션:

--color=auto: 일치하는 텍스트에 색상을 지정하고 강조 표시합니다. : 대소문자 무시

  -o: 일치하는 문자열만 표시

  -v: 패턴과 일치하지 않는 행 표시

  -E: 확장 정규식 사용 지원

  -q: 자동 모드, 즉 이면 정보가 출력되지 않습니다

   -A #: 패턴과 일치하는 행과 그 뒤의 # 행을 표시합니다

  -B #: 패턴과 일치하는 행과 그 앞의 # 행을 표시합니다

  -C #: 패턴과 일치하는 줄과 그 앞의 # 줄을 표시합니다

 패턴 일치 줄과 앞과 뒤의 # 줄을 표시합니다

참고: grep 일치를 사용할 때 큰 따옴표(작은 따옴표는 강한 따옴표)를 사용해야 합니다. 시스템이 이를 매개변수나 특수 명령으로 착각하여 오류를 보고하는 것을 방지합니다.

확장 grep 사용법

사용법:


egrep [OPTIONS] PATTERN [FILE...]
grep -E [OPTIONS] PATTERN [FILE...]
로그인 후 복사

  -i: 대소문자 무시
  -o: 일치하는 문자열 자체만 표시
  -v: 패턴과 일치하지 않는 표시 -q: 무음 모드, 즉 정보가 출력되지 않습니다
 -A#: 패턴과 일치하는 줄과 그 뒤의 #줄을 표시합니다
  -B#: 패턴과 일치하는 줄과 그 앞의 #줄을 표시합니다
  -C # : 패턴과 일치하는 행과 앞뒤의 # 행을 표시합니다.
   -G: 기본 정규식 지원

grep 정규식 메타문자

  '^': 행의 시작 부분 고정

  '$' : 줄 끝의 앵커

  '.': 임의의 한 문자와 일치

  '*': 0개 이상의 이전 문자와 일치

  '?': 선행 문자를 0 또는 1번 일치

'+' : 그 앞의 문자를 1번 이상 일치시킵니다.

  '{m}': 그 앞의 문자를 m번 일치합니다(이스케이프 문자의 경우)

  '{m,n}': 그 앞의 문자와 최소 m번 일치 최대 n번

 []': 지정된 범위 내의 문자와 일치 | '[^]' 지정된 범위 밖의 단일 문자와 일치

 '<' 또는 'b': 앵커 단어 제목, '> ;' 또는 'b': 앵커 단어 끝(사용 가능 : 완전한 단어 일치)

  '()': 여러 문자를 전체로 처리

역참조: 이전 항목 인용 그룹화 괄호

그룹화 괄호의 패턴과 일치하는 내용은 정규식 엔진에 의해 내부 변수에 자동으로 기록될 수 있습니다.

 1: 패턴은 왼쪽부터 시작하고 첫 번째 왼쪽 괄호와 사이의 패턴과 일치하는 내용 일치하는 오른쪽 괄호

 2: 패턴은 왼쪽부터 시작하고, 두 번째 왼쪽 괄호와 일치하는 오른쪽 괄호 사이의 패턴과 내용이 일치합니다...

 확장 정규식은 정규식과 약간 다릅니다:

 [] ': 여전히 지정된 범위 내의 단일 문자와 일치하지만 특수한 일치 방법이 많이 있습니다. T [: Digit:] 임의의 단일 숫자와 일치

[: LOWER:] 임의의 단일 소문자와 일치

[: upper:] 임의의 단일 대문자와 일치

[: alpha:] 임의의 단일 문자와 일치

[:: alnum:]은 임의의 단일 문자 또는 숫자와 일치합니다

  [:punct:]는 임의의 단일 기호와 일치합니다

  [:space:]는 단일 공백과 일치합니다

 일부 위치에서는 이스케이프 문자 사용이 취소되었습니다.

 '?' : 일치합니다. 선행 문자가 0회 또는 1회입니다.

 '+': 선행 문자와 1회 이상 일치합니다.

 '{m}': 선행 문자와 m회 일치합니다(이스케이프 문자의 경우). ,n}': 앞의 문자를 최소 m번, 최대 n번 일치시킵니다.

 (): 하나 이상의 문자를 함께 묶고 전체적으로 처리합니다. 역참조는 평소와 같이 사용됩니다.

 |': 또는 (참고: 'C|cat'은 C와 cat이고, '(C|c)at는 Cat과 cat'입니다.)

연습 질문:

1. 현재 사용자 이름을 나열하세요. 참고: 동일한 사용자가 여러 번 로그인하면 한 번만 표시됩니다

[root@localhost ~]# who | cut -d&#39; &#39; -f1|uniq
root
로그인 후 복사

  2、取出最后登录到当前系统的用户的相关信息


[root@localhost ~]# id `last | head -1 | cut -d&#39; &#39; -f1`
uid=0(root) gid=0(root) groups=0(root)
로그인 후 복사

  3.取出当前系统上被用户当做其默认shell最多的那个shell


[root@localhost ~]# cut -d&#39;:&#39; -f7 /etc/passwd|uniq -c|sort -n|tail -1|cut -d&#39; &#39; -f7
/sbin/nologin
로그인 후 복사

  4.将/etc/passd中的第三个字段设置最大的后10个用户的信息全部改为大写保存至/tmp/maxuser.txt文件中


[root@localhost ~]# sort -t&#39;:&#39; -k3 -n /etc/passwd|tail -10|tr &#39;a-z&#39; &#39;A-Z&#39; >/tmp/maxusers.txt
[root@localhost ~]# cat /tmp/maxusers.txt 
NOBODY:X:99:99:NOBODY:/:/SBIN/NOLOGIN
SYSTEMD-NETWORK:X:192:192:SYSTEMD NETWORK MANAGEMENT:/:/SBIN/NOLOGIN
NGINX:X:996:994:NGINX WEB SERVER:/VAR/LIB/NGINX:/SBIN/NOLOGIN
CHRONY:X:997:995::/VAR/LIB/CHRONY:/SBIN/NOLOGIN
POLKITD:X:998:996:USER FOR POLKITD:/:/SBIN/NOLOGIN
SYSTEMD-BUS-PROXY:X:999:997:SYSTEMD BUS PROXY:/:/SBIN/NOLOGIN
DINGJIE:X:1000:1000:DINGJIE:/HOME/DINGJIE:/BIN/BASH
JEFF:X:1001:1024:WOSHIDASHUAIBI:/HOME/JEFF:/BIN/BASH
EGON:X:1002:1002::/HOME/EGON:/BIN/BASH
NFSNOBODY:X:65534:65534:ANONYMOUS NFS USER:/VAR/LIB/NFS:/SBIN/NOLOGIN
로그인 후 복사

  5.取出当前主机的IP地址


[root@localhost ~]# ifconfig | egrep "inet.*broadcast.*"|cut -d&#39; &#39; -f10
192.168.0.133
로그인 후 복사

  6.列出/etc目录下所有已.conf结尾的文件的文件名,并将其名字转换为大写后保存至/tmp/etc.conf文件中


[root@localhost ~]# find /etc -name &#39;*.conf&#39; | egrep -o "[^/]*(\.conf)$"|tr &#39;a-z&#39; &#39;A-Z&#39; >/tmp/etc.conf
[root@localhost ~]# cat /tmp/etc.conf 
RESOLV.CONF
CA-LEGACY.CONF
FASTESTMIRROR.CONF
LANGPACKS.CONF
SYSTEMD.CONF
VERSION-GROUPS.CONF
LVM.CONF
LVMLOCAL.CONF
ASOUND.CONF
LDAP.CONF
MLX4.CONF
RDMA.CONF
SMTPD.CONF
로그인 후 복사

  7.显示/var目录下一级子目录或文件的总数


[root@localhost ~]# ls /var | wc -l
로그인 후 복사

  8.取出/etc/group第三个字段数值最小的10个组的名字


[root@localhost ~]# sort -t: -k3 -n /etc/group|head -10 |cut -d&#39;:&#39; -f1
root
bin
daemon
sys
adm
tty
disk
lp
mem
kmem
로그인 후 복사

  9.将/etc/fstab和/etc/issue文件的内容合并为同一个内容后保存至/tmp/etc.test文件中


[root@localhost ~]# cat /etc/fstab /etc/issue > /tmp/etc.test
[root@localhost ~]# cat /tmp/etc.test 
#
# /etc/fstab
# Created by anaconda on Sat May 13 10:12:58 2017
#
# Accessible filesystems, by reference, are maintained under &#39;/dev/disk&#39;
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
/dev/mapper/cl-root   /            xfs   defaults    0 0
UUID=2789d01a-4e2b-47a5-9c3c-537641648663 /boot          xfs   defaults    0 0
/dev/mapper/cl-swap   swap          swap  defaults    0 0
\S
Kernel \r on an \m
로그인 후 복사

위 내용은 Linux grep 및 정규식에 대한 간략한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿