grep은 정규식을 사용하여 텍스트를 검색하고 일치하는 줄을 인쇄할 수 있는 강력한 텍스트 검색 도구입니다. 일반적으로 grep에는 grep, egrep(grep -E와 동일) 및 fgrep의 세 가지 버전이 있습니다. egrep은 확장 grep이고 fgrep은 빠른 grep입니다(검색 텍스트에 대한 고정 문자열, 정규식 참조를 지원하지 않지만 쿼리는 매우 빠릅니다). grep은 Linux 텍스트 처리의 삼총사 중 하나입니다.
사용 방법: grep [OPTIONS] PATTERN [FILE...]
grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
일반 옵션:
- -color=auto: 일치하는 텍스트에 색상을 지정하고 강조 표시합니다.
-i: 문자의 대소문자를 무시합니다.
-o: 일치하는 문자열만 표시합니다.
-v: 패턴과 일치할 수 없는 줄을 표시합니다.
-E: 확장 정규식 사용을 지원합니다. -q: 자동 모드, 즉 정보가 출력되지 않습니다. -A #: 패턴과 일치하는 행을 표시하고 다음 #행을 표시합니다 -B #: 패턴과 일치하는 라인과 전후의 # 라인을 표시합니다 -C #: 패턴과 일치하는 라인과 전후의 # 라인을 표시합니다Note: grep 매칭을 사용할 때는 double을 사용해야 합니다 따옴표(작은따옴표는 강력함) 참조)를 사용하여 시스템이 이를 매개변수나 특수 명령으로 착각하여 오류를 보고하는 것을 방지합니다.
확장 grep 사용법사용법:egrep [OPTIONS] PATTERN [FILE...]
grep -E [OPTIONS] PATTERN [FILE...]
-i: 문자 크기를 무시합니다. 쓰기 -o : 일치하는 문자열 자체만 표시
-v : 패턴과 일치하지 않는 줄 표시
-q : 무음 모드, 즉 아무 정보도 출력하지 않음
-A # : 패턴과 일치하는 줄과 해당 -B #: 패턴과 일치하는 행과 전후의 # 행을 표시합니다. -C #: 패턴과 일치하는 행과 전후의 # 행을 표시합니다.
-G: 기본 정규식 지원
grep 정규식 수식 문자
' ?': 선행 문자와 0회 또는 1회 일치합니다. '+': 선행 문자와 1회 이상 일치합니다. '{m}': 선행 문자와 m회 일치합니다(Escape 문자의 경우) '{ m,n}': 앞의 문자를 최소 m번, 최대 n번 일치 '[]': 지정된 범위 내의 문자와 일치 | '[^]' 지정된 범위 밖의 문자와 일치 의 모든 단일 문자 '714c03ceb6a56eeb88a0808d43477c69' 또는 'b': 단어의 끝을 고정합니다(사용 가능 cd22d989ebecf0466bc673f30afdaf24: 전체 단어와 일치) '()' 여러 문자를 전체적으로 처리
역참조: 이전 그룹 괄호의 패턴과 일치하는 문자를 참조
그룹 괄호의 패턴과 일치하는 내용은 정규식 엔진에 의해 자동으로 기록될 수 있습니다. 내부 변수:
1: 패턴이 왼쪽부터 시작하고, 첫 번째 왼쪽 괄호와 일치하는 오른쪽 괄호 사이의 패턴과 내용이 일치합니다.
2: 패턴이 왼쪽부터 시작하고, 첫 번째 내용이 일치합니다. 두 개의 왼쪽 괄호와 일치하는 오른쪽 괄호 사이의 패턴으로...
확장 정규식은 정규식과 약간 다릅니다:
'[]': 여전히 지정된 범위와 일치하지만 단일 문자가 있습니다. 많은 특별한 매칭 방법.
[:digit:]는 모든 한 자리 숫자와 일치합니다 [:lower:]는 모든 단일 소문자와 일치합니다
[:alnum:]은 모든 단일 문자 또는 숫자와 일치합니다[: punct:]는 모든 단일 기호와 일치합니다
[:space:]는 단일 공백과 일치합니다 일부 위치에서는 이스케이프 문자 사용이 취소되었습니다. '?': 그 앞의 문자를 0 또는 1번 일치시킵니다. '+': 앞의 문자를 1번 이상 일치합니다. '{m}': 앞의 문자를 m번 일치합니다(이스케이프 문자의 경우)'{m,n}': 앞의 문자를 최소한 일치합니다. m번, 최대 n번 (): 하나 이상의 문자를 함께 묶고 전체적으로 처리합니다. 역참조는 평소와 같이 사용됩니다. '|': 또는 (
Note
: 'C|cat'은 C와 cat, '(C|c)at는 Cat과 cat')연습 질문: 1. 현재 시스템 나열 사용자 이름 참고: 동일한 사용자가 여러 번 로그인하면 한 번만 표시됩니다[root@localhost ~]# who | cut -d' ' -f1|uniqroot
2. 현재 시스템에 마지막으로 로그인한 사용자의 관련 정보를 가져옵니다
[root@localhost ~]# id `last | head -1 | cut -d' ' -f1` uid=0(root) gid=0(root) groups=0(root)3. 현재 시스템에서 대부분의 사용자가 기본 쉘로 간주하는 쉘을 꺼내세요
[root@localhost ~]# cut -d':' -f7 /etc/passwd|uniq -c|sort -n|tail -1|cut -d' ' -f7/sbin/nologin
4.将/etc/passd中的第三个字段设置最大的后10个用户的信息全部改为大写保存至/tmp/maxuser.txt文件中
[root@localhost ~]# sort -t':' -k3 -n /etc/passwd|tail -10|tr 'a-z' 'A-Z' >/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' ' -f10192.168.0.133
6.列出/etc目录下所有已.conf结尾的文件的文件名,并将其名字转换为大写后保存至/tmp/etc.conf文件中
[root@localhost ~]# find /etc -name '*.conf' | egrep -o "[^/]*(\.conf)$"|tr 'a-z' 'A-Z' >/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 -l21
8.取出/etc/group第三个字段数值最小的10个组的名字
[root@localhost ~]# sort -t: -k3 -n /etc/group|head -10 |cut -d':' -f1 root bin daemon sys adm tty disklpmem 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 '/dev/disk'# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info#/dev/mapper/cl-root / xfs defaults 0 0UUID=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 중국어 웹사이트의 기타 관련 기사를 참조하세요!