正则表达式基础

正则表达式正则表达式   

元字符:       

.       点表示任意单个字符 最少一次       

\w      匹配字母、数字、下划线、或汉字。       

\s      匹配任意空白字符       

\d      匹配数字       

\b      匹配字符的开始或结束       

^       匹配首字符       

$       匹配末尾字符       

\       转义字符   

反义:       

\W      匹配字母、数字、下划线、或汉字。       

\S      匹配任意空白字符       

\D      匹配数字       

\B      匹配字符的开始或结束       

[^n]    匹配除了n的字符   

限定符:       

*       重复任意次       

+       至少一次       

?      重复0次或1次       

{n}     重复n次       

{n,}    至少重复n次,无上线++ {,n} 至多重复n次,最少0次 (不重复)       

{n,m}   至少重复n次,至多重复m次。(字符重复n到m次)       

[1-9]   重复指定范围内的字符    贪婪与懒惰模式:       

*?     匹配任意字符(尽量少的次数)       

+?     重复一次或多次(尽量少的次数)       

??      重复0次或1次(尽量少的次数)       

{n,m}?  重复n到m次(尽量少的次数)       

{n,}?   至少重复n次(尽量少的次数)

高级进阶:    捕获:        (exp)        

匹配括号里的字符(串),并自动保存到自动命名的组里       

(?<name>ex)  匹配ex,并捕获文本保存到名字为name的组里       

(?:exp)      匹配exp 不捕获文本,也不匹配组号   

零宽断言:        (?=exp)       匹配exp前面的位置       

(?<=exp)      匹配exp后面的位置       

(?<!exp)      匹配后面非exp的位置       

(?<!exp)      匹配前面非exp的位置       

shell不支持零宽断言

实例:

1. 取出IP地址的方法 

a.

[root@yanghua shiyan]# ifconfig eth0|grep ‘inet addr’|sed ‘s/^.*addr://g’|sed ‘s/B.*//g’ 192.168.210.128  

正则匹配的秘籍: 匹配目标之前的内容时,用“^.*”任意字符开头,结尾给出具体字符, 例如:

取IP

[root@yanghua shiyan]# ifconfig eth0|grep ‘inet addr’          inet addr:192.168.210.128  Bcast:192.168.210.255  Mask:255.255.255.0

匹配目标之后的内容时,用“.*$”任意字符结尾,开头给出具字符。

[root@yanghua shiyan]#  ifconfig eth0|grep ‘inet addr’|sed ‘s/^.*addr://g’ 192.168.210.128  Bcast:192.168.210.255  Mask:255.255.255.0
 b.

[root@yanghua shiyan]# ifconfig eth0|sed -rn ‘s/^.*r:(.*)  Bc.*/\1/p’ 192.168.210.128 此处用到了Sed的高级用法:捕获功能 (exp)         匹配括号里的字符(串),并自动保存到自动命名的组里 但是要注意格式:

sed -n -r s/(exp)正则/默认的组’\1 \2’/p’命令’
 c.

sed超复杂用法:(仅供参考)

[root@yanghua shiyan]# ifconfig eth0|sed -rn ‘s/^.*r:([0-9]{,3}.[0-9]{,3}.[0-9]{,3}.[0-9]{,3})  Bc.*/\1/p’ 192.168.210.128
 实战:取出IP和网关

[root@yanghua ~]# ifconfig eth0 eth0      

Link encap:Ethernet  HWaddr 00:0C:29:14:DD:D3   inet addr:192.168.210.128  Bcast:192.168.210.255  Mask:255.255.255.0 inet6 addr: fe80::20c:29ff:fe14:ddd3/64 Scope:Link UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1 RX packets:3494 errors:0 dropped:0 overruns:0 frame:0 TX packets:2214 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000  RX bytes:306833 (299.6 KiB)  TX bytes:234127 (228.6 KiB) Interrupt:19 Base address:0x2000 

[root@yanghua shiyan]# ifconfig eth0|sed -r -n ‘s/^.*r:(.*)  Bcast:(.*)  Ma.*/\1\n\2/p’ 192.168.210.128 192.168.210.255

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/88394

(0)
小白Linux小白Linux
上一篇 2017-11-14
下一篇 2017-11-14

相关推荐

  • 马哥网络教育班第21期+第四周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限 [root@CentOS6 ~]# cp -r /etc/skel /home/tuser1 [root@CentOS6 ~]# chmod&nb…

    Linux干货 2016-07-29
  • sed命令用法

    sed命令 [option]  “script”  file sed命令是一种行编辑工具,他是逐行对文件进行编辑。sed命令有一个模式空间,他将一行命令读取进模式空间进行编辑,完成后将本行数据打印再读取下一行数据进行处理。 option: -n:静默模式不显示模式空间内容 -f:从指定文件中读取 -i:修改源文件(-i.###会自动将原文…

    Linux干货 2016-08-12
  • 配置Nginx作为反向代理服务器

    配置Nginx作为反向代理服务器      一、nginx作为反向代理的工作模型: 1、nginx作为反向代理的工作模型       nginx工作在应用层,其能理解并可以提取出http请求报文中的首部信息中的请求方法、url、http协议版本等信息。   &…

    Linux干货 2016-10-29
  • 自制Linux系统

    自制Linux系统 1.首选准备一台Linux虚拟机并添加一块新硬盘 2.分区并创建文件系统,创建两个必要的分区根分区和boot分区 fdisk /dev/sdb  分区 mke2fs -t ext4 /dev/sdb1    创建boot文件系统 mke2f…

    Linux干货 2016-09-16
  • Linux文本处理三剑客之一sed

    这周我们学习了文本处理工具三剑客之一的sed,对于之前学的grep同样的重要,也同样是一个难点。sed是针对一个文件或者多个文件一行一行处理的,它处理的时候,把当前处理的行存储在模式空间,处理完成后,把缓冲区内容输出到屏幕上,接着处理下一行。直到文件末尾。原文件并没有经过更改。 1、sed一些常用的选项     -n …

    2017-08-26
  • 第六周作业

    1、简述osi七层模型和TCP/IP五层模型 应用层 运行着应用程序的协议http、ftp、tftp等 表示层 将应用层所编辑的数据进行加密或解密,没有协议 会话层 决定一次数据传输发起和接收会话请求,没有协议 传输层 根据选着的协议类型,决定是否将数据分割或重组,协议:tcp、udp等 网络层 编辑逻辑地址信息(原站点、目的站点)和路由选着(ARP)协议:…

    2018-02-06