正则表达式基础

正则表达式正则表达式   

元字符:       

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

\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

相关推荐

  • linux文件基本权限讲解

    linux文件基本权限讲解 Linux系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。为了保护系统的安全性,Linux系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。 Linux系统中一切都是文件,文件和目录的所属与权限——来分别规定所有者、所有组、其余人的读,写,执行权限。 在Linux中我们可以使用ll或者ls –…

    Linux干货 2016-09-05
  • 生产环境日志审计

         日志审计,就是记录所有系统和相关用户行为的信息,并且可以自动分析,处理。在中小企业环境中,一般都是在单个服务器上记录日志,而大型企业的生产环境当中,会有专门的日志服务器乃至集群。本文通过sudo配合centos自带的rsyslog(syslog)服务,进行日志审计。    &nb…

    Linux干货 2016-10-20
  • N25-第二周总结

    linux bassic The second week of blogging 一、linux中的文件,及文件操作管理命令 1. 文件概念 存储空间存储的一段流式数据,对数据可以做到按名存取。 linux中的文件具有的特点是:可通过操作系统或者程序对外提供信息,也能对内输入信息,可以被创建,删除。linux中,文件有特别重要的意义,他们为操作系统和设备提供…

    Linux干货 2016-12-11
  • 0805作业

    课堂练习 1.找出ifconfig 命令结果中本机的所有IPv4 地址   ifconfig|tr -cs '[0-9].' '\n'|sort -ut '.' -k3 2.查出分区空间使用率的最大百分比值   df|tr -s ' '|cut -d&quot…

    Linux干货 2016-08-07
  • Linux系统基础(二)

    一、Linux文件管理命令及其常用方法 1、cd(切换目录)这个命令应该是Linux中用的最频繁的一个命令之一了,因为我们经常需要进行目录的切换。在详解这个命令之前,首先得补充一个重要的知识,就是我们常用的一些比较特殊的目录: .        代表当前目录 .. &n…

    Linux干货 2016-09-24
  • tomcat之-从AT到Cluster

    本文导航 一、    LAMT搭建以及部署应用        1、LAMT部署                   (1)、安装Apache     …

    2017-02-13