系统相关
首页 > 系统相关> > linux 正则表达式与实践

linux 正则表达式与实践

作者:互联网

正则表达式基础

 

准备

(1)alias grep='grep --color=auto' 易于显示

(2)LC_ALL=C,字符集,设置环境变量,字符顺序

 

基础正则

1)^word  匹配以Word开头的内容 vi/vim 里^代表一行的开头

2)word$  匹配以Word结尾的内容 vi/vim 里$代表一行的结尾

3)^$    表示空行

#过滤空行,并显示行号

[root@wen data]# grep -n "^$" lrs.txt

2:

4:

6:

8:

#过滤掉所有空行不显示

[root@wen data]# grep -v "^$" lrs.txt

You're in a battle with

A bulletproof heart

You really got me, got me

A bulletproof heart.

 

4). 代表且只能代表任意一个字符

5)\ 转义符号,让特殊字符显示其原型 \$ \.

6)* 重复0个或多个前面一个字符,例 o* 匹配 没有o 有一个或多个 oo  oooooo……

7).* 匹配所有字符 延伸 ^.*以任意多个字符开头  .*$以任意多个字符结尾

点(.)含义总结

1.当前目录

2.使得文件生效 相当于source

3.隐藏文件

4.任意一个字符(grep正则)

#只显示匹配到的内容

[root@wen data]# grep -on "you" lrs.txt

9:you

12:you

 

8).[abc] 匹配字符集合内的任意一个字符[a-zA-Z],[0-9]

9).[~abc]  匹配不包含~后的任意一个字符的内容

                          ~为去反,注意和中括号外面以……开头区别

                          [root@wen data]# grep "[~ot]" lrs.txt

        

10.a\{n,m\} 重复n到m次,前一个重复的字符 如果用egrep/sed -r 可以去掉斜线

         a\{n,\}  重复至少n次,前一个重复字符 如果用egrep或sed -r 可以去掉斜线

         a\{n\}  重复n次,前一个重复字符  如果用egrep/sed -r 可以去掉斜线

         a\{,m\}  重复最多m次

扩展

         11. +  表示 重复一个或一个以上 前面的字符(*是0或多个)

         [root@wen data]# grep -E "on+" lrs.txt

         So if you don't know how to

         I'm not gonna break your fall.

         12. ?  表示 0或一个 前面的字符(.是有且只有一个)

         13. |  表示同时过滤多个字符串

         root@wen data]# grep -E "3306|1521" /etc/services

         mysql 3306/tcp # MySQL

         mysql 3306/udp # MySQL

         ncube-lm 1521/tcp # nCube License Manager

         ncube-lm 1521/udp # nCube License Manager

14.() 分组过滤,后向引用

         [root@wen data]# grep -E "g(la|oo)d" lrs.txt

         glad

         good

 

        

#POSIX字符类(了解)

[:lower:] 匹配小写(麻烦,直接用下面的例子)

         root@wen data]# grep -E "[a-z]" lrs.txt

         You're in a battle with

         A bulletproof heart

         You really got me, got me

         A bulletproof heart.

 

 

#元字符

\b 单词边界 只过滤单词

         [root@wen data]# grep -E "\byou\b" lrs.txt

         So if you don't know how to

         [root@wen data]# grep -E "you" lrs.txt

         So if you don't know how to

         I'm not gonna break your fall.

 

#三剑客grep总结

         -a 在二进制文件中,以文本文件的方式搜索数据

         -c 计算找到“搜索字符串”的次数

         -o 仅显示出匹配grep的内容(用于统计出现在文中的次数)

         -i 忽略大小写的不同,所有大小写视为相同

         -n  匹配的内容在其行首显示行号

         -v  反向选择,即显示没有“搜索字符串”内容的那一行

         -E  扩展的grep ,即egrep

         --color=auto  以特定颜色高亮显示匹配关键字

         -C #除了显示匹配行外,显示该行前后的num行

         -B #除了显示匹配行外,显示该行之前的num行

         -A #除了显示匹配行外,显示该行之后的num行   

 


 

 

正则表达式实战

一,将第一列与最后一列交换位置

[root@wen data]# tail /etc/passwd

vcsa:x:69:69:virtual console memory owner:/dev:/sbin/nologin

abrt:x:173:173::/etc/abrt:/sbin/nologin

haldaemon:x:68:68:HAL daemon:/:/sbin/nologin

ntp:x:38:38::/etc/ntp:/sbin/nologin

saslauth:x:499:76:Saslauthd user:/var/empty/saslauth:/sbin/nologin

postfix:x:89:89::/var/spool/postfix:/sbin/nologin

sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin

tcpdump:x:72:72::/:/sbin/nologin

mygirl:x:500:500::/home/mygirl:/bin/bash

fadewalk:x:501:501::/home/fadewalk:/bin/bash

 

 

[root@wen data]# tail /etc/passwd |sed -nr 's#([^:]+)(:.*:)(/.*$)#\3\2\1#gp'  #第一个([^:])取非:开头的

/sbin/nologin:x:69:69:virtual console memory owner:/dev:vcsa

/sbin/nologin:x:173:173::/etc/abrt:abrt

/sbin/nologin:x:68:68:HAL daemon:/:haldaemon

/sbin/nologin:x:38:38::/etc/ntp:ntp

/sbin/nologin:x:499:76:Saslauthd user:/var/empty/saslauth:saslauth

/sbin/nologin:x:89:89::/var/spool/postfix:postfix

/sbin/nologin:x:74:74:Privilege-separated SSH:/var/empty/sshd:sshd

/sbin/nologin:x:72:72::/:tcpdump

/bin/bash:x:500:500::/home/mygirl:mygirl

/bin/bash:x:501:501::/home/fadewalk:fadewalk

 

二,取IP或数字

1.取数字

[root@wen ~]# ifconfig | sed -nr 's#^.*dr:(.*) B.*$#\1#gp'

192.168.59.130

[root@wen ~]# stat /etc/hosts

File: "/etc/hosts"

Size: 158 Blocks: 8 IO Block: 4096 普通文件

Device: 802h/2050d Inode: 40 Links: 2

Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)

Access: 2017-10-11 20:22:15.436493668 +0800

Modify: 2010-01-12 21:28:22.000000000 +0800

Change: 2017-08-30 05:59:08.040858188 +0800

取出644

[root@wen ~]# stat /etc/hosts|sed -nr 's#^.*0(.*)/-rw.*$#\1#gp'

644

[root@wen ~]# stat /etc/hosts|sed -nr 's#^.*\(0(.*)/-rw.*$#\1#gp'

644

2.取IP

[root@wen data]# ifconfig eth0

eth0      Link encap:Ethernet  HWaddr 00:0C:29:E9:95:DD 

          inet addr:192.168.59.130  Bcast:192.168.59.255  Mask:255.255.255.0

          inet6 addr: fe80::20c:29ff:fee9:95dd/64 Scope:Link

          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1

          RX packets:6964 errors:0 dropped:0 overruns:0 frame:0

          TX packets:4430 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:1000

          RX bytes:606332 (592.1 KiB)  TX bytes:489934 (478.4 KiB)

 

[root@wen ~]# ifconfig | sed -n '2s#^.*dr:##p'|sed 's# B.*$##g'

192.168.59.130

 

 

grep取IP

[root@wen ~]# ifconfig eth0 |grep "ddr:[0-9.]*"

          inet addr:192.168.13.128  Bcast:192.168.13.255  Mask:255.255.255.0

          inet6 addr: fe80::20c:29ff:fee9:95dd/64 Scope:Link

[root@wen ~]# ifconfig eth0 |grep -o "inet addr:[0-9.]*"

inet addr:192.168.13.128

[root@wen ~]# ifconfig eth0 |grep -o "inet addr:[0-9.]*"|grep -o "[0-9]*"

192

168

13

128

[root@wen ~]# ifconfig eth0 |grep -o "inet addr:[0-9.]*"|grep -o "[0-9.]*"

192.168.13.128

 

 

 

 

 

 

 

 

标签:sbin,grep,正则表达式,data,nologin,wen,实践,linux,root
来源: https://blog.51cto.com/wenyule/2838806