在使用sed和gawk时如果能够熟练的使用正则表达式,可以准确的过滤到自己需要的信息

Linux中,有两种流行的正则表达式引擎:

  • POSIX基础正则表达式,BRE引擎
  • POSIX扩展正则表达式,ERE引擎

一、BRE模式

1.1 纯文本

基本上没什么可写的,区分大小写,多个空格也可以匹配。

1.2 特殊字符

正则表达式识别的特殊字符包括这些,如果需要使用特殊字符,需要转义符(\)。

.*[]^${}\+?|()

1.3 锚字符

  • 或字符(^)锁定在行首
  • 美元符($)锁定在行尾
  • 两个组合(^$)可以过滤空行
sed -n '/^this/p' data3
echo "This ^ is a test" | sed -n '/s ^/p' echo "This is a good book" | sed -n '/book$/p'
echo "This book is good" | sed -n '/book$/p' sed -n '/^this is a test$/p' data4
sed '/^$/d' data5

使用例子

1.4 点号字符

匹配除换行符之外的任意单个字符。

sed -n '/.at/p' data6

1.5 字符组

使用方括号来定义字符组

sed -n '/[ch]at/p' data6
echo "Yes" | sed -n '/[Yy]es/p'

1.6 排除型字符组

也可以反转字符组的作用,在字符组的开头加个脱字符

sed -n '/[^ch]at/p' data6

1.7 区间

用破折号可以表示字符中间的内容,第一个字符,破折号,最后一个字符

sed -n '/^[0-9][0-9][0-9][0-9][0-9]$/p' data8

1.8 特殊的字符组

  • [[:alpha:]]       匹配任意字母字符,不管是大写还是小写
  • [[:alnum:]]           匹配任意字母数字字符0~9、A~Z或a~z
  • [[:blank::]]           匹配空格或制表符
  • [[:digit:]]              匹配0~9之间的数字
  • [[:lower:]]            匹配小写字母字符a~z
  • [[:print:]]             匹配仍以可打印字符
  • [[:punct:]]           匹配标点符号
  • [[:space:]]          匹配任意空白字符:空格、制表符、NL、FF、VT和CR
  • [[:upper:]]          匹配任意大写字母字符A~Z

这些表达式可以像普通字符组一样使用。

echo "abc" | sed -n '/[[:digit:]]/p'
echo "abc" | sed -n '/[[:alpha:]]/p'
echo "abc123" | sed -n '/[[:digit:]]/p'

1.9 星号

星号表明该字符必须在匹配模式的文本中出现0次或多次

echo "ik" | sed -n '/ie*k/p'
echo "iek" | sed -n '/ie*k/p'
echo "ieek" | sed -n '/ie*k/p'
echo "ieeek" | sed -n '/ie*k/p'

二、ERE模式

2.1 问号

问号表明前面的字符可以出现0次或1次。

echo "bt" | gawk '/be?t/{print $0}'
bt
echo "bet" | gawk '/be?t/{print $0}'
bet
echo "beet" | gawk '/be?t/{print $0}' echo "beeet" | gawk '/be?t/{print $0}'

2.2 加号

加号表明前面的字符可以出现1次或多次,但必须至少出现1次。

echo "beeet" | gawk '/be+t/{print $0}'

echo "beet" | gawk '/be+t/{print $0}'

echo "bet" | gawk '/be+t/{print $0}'

2.3 花括号

花括号允许你可重复的正则表达式指定一个上限。这通常成为间隔,可以用两种格式来指定区间。

m:正则表达式准确出现m次。

m,n:正则表达式至少出现m次,至多n次。

echo "bt" | gawk --re-interval '/b[ae]{1,2}t/{print $0}'

echo "bat" | gawk --re-interval '/b[ae]{1,2}t/{print $0}'

echo "bet" | gawk --re-interval '/b[ae]{1,2}t/{print $0}'

2.4 管道符号

就是linux里的|符号,一样的管道。应该是逻辑或的感觉

echo "The cat is asleep" | gawk '/cat|dog/{print $0}'
The cat is asleep
echo "The dog is asleep" | gawk '/cat|dog/{print $0}'
The dog is asleep
echo "The sheep is asleep" | gawk '/cat|dog/{print $0}'

2.5 表达式分组

使用园括号进行分组,当你将正则表达式模式分组时,该组会被视为一个标准字符。

echo "Sat" | gawk '/Sat(urday)?/{print $0}'
Sat
echo "Saturday" | gawk '/Sat(urday)?/{print $0}' echo "cat" | gawk '/(c|b)a(b|t)/{print $0}'
cat
echo "cab" | gawk '/(c|b)a(b|t)/{print $0}'
cab
echo "bat" | gawk '/(c|b)a(b|t)/{print $0}'
bat
echo "bab" | gawk '/(c|b)a(b|t)/{print $0}'
bab
echo "tab" | gawk '/(c|b)a(b|t)/{print $0}' echo "tac" | gawk '/(c|b)a(b|t)/{print $0}'

shell学习----正则表达式的更多相关文章

  1. bash shell学习-正则表达式基础 (笔记)

    A gentleman is open-minded and optimistic; a small person is narrow-minded and pessimistic. "君子 ...

  2. Shell学习之结合正则表达式与通配符的使用(五)

    Shell学习之结合正则表达式与通配符的使用 目录 通配符 正则表达式与通配符 通配符 通配符的使用 正则表达式 正则表达式 正则表达式的使用 通配符 正则表达式与通配符 正则表达式用来在文件中匹配符 ...

  3. shell学习笔记

    shell学习笔记 .查看/etc/shells,看看有几个可用的Shell . 曾经用过的命令存在.bash_history中,但是~/.bash_history记录的是前一次登录前记录的所有指令, ...

  4. shell学习总结之自定义函数

    shell学习总结之自定义函数 Myfun (){ echo -n "now i is $i " ! [ "$i" ] && exit ; ec ...

  5. SHELL学习笔记----IF条件判断,判断条件

    SHELL学习笔记----IF条件判断,判断条件 前言: 无论什么编程语言都离不开条件判断.SHELL也不例外.  if list then           do something here   ...

  6. shell学习指南-阅读笔记

    shell学习指南真不是刚开始学习shell应该看得书,虽然其中讲了简单的linux命令,shell语法等,但是每章也有些深入和生僻地方,我想如果我刚学shell看到这样的地方一定会头疼的要死.或许也 ...

  7. 【转】shell学习笔记(一)——学习目的性、特殊字符、运算符等

    1 学习shell的目的性 写之前我们先来搞清楚为什么要学shell,学习要有目的性 shell简单.灵活.高效,特别适合处理一些系统管理方面的小问题 shell可以实现自动化管理,让系统管理员的工作 ...

  8. Shell学习之条件测试(四)

    Shell学习之条件测试 目录 逻辑测试 文件测试 数值比较 字符串比较 逻辑测试 格式: [ 表达式 ] 操作符 [ 表达式2 ] …… 命令1 操作符 命令2 …… 常用的操作符 ( 注意:-a和 ...

  9. Shell学习之环境变量配置文件(三)

    Shell学习之环境变量配置文件 目录 环境变量配置文件简介 环境变量配置文件作用 其他配置文件和登录信息 环境变量配置文件简介 环境变量配置文件简介 环境变量配置文件中主要是定义对系统操作环境生效的 ...

随机推荐

  1. python写一个查询接口

    知识点: 1.flask_sqlalchemy查询: Flask-SQLAlchemy 在您的 Model 类上提供了 query 属性.当您访问它时,您会得到一个新的所有记录的查询对象.在使用 al ...

  2. 关于 token

    用户在浏览器做一系列操作,后台服务怎么判断这些操作是来自同一个用户? 1. seesion 用户登录后,后台生成 sessionid 返回给浏览器,浏览器的每次请求带上 sessionid,后台关联 ...

  3. 1.k8s.资源清单

    #k8s常用资源 工作负载:Pod,rs(ReplicasSet),deploy(Deployment),sts(StatefulSet),ds(DaemonSet),Job,Cronjob 服务发现 ...

  4. Java 基础-基本数据类型与表达式

    基本数据类型 基本概念 标识符 标识符与内存中的某个位置对应,Java 中标识符的规范如下: 必须由大小写字母.下划线.美元符号.数字组成 首字母只能是大小写字母.下划线.美元符号 变量 变量的值可以 ...

  5. TensorFlow学习笔记7-深度前馈网络(多层感知机)

    深度前馈网络(前馈神经网络,多层感知机) 神经网络基本概念 前馈神经网络在模型输出和模型本身之间没有反馈连接;前馈神经网络包含反馈连接时,称为循环神经网络. 前馈神经网络用有向无环图表示. 设三个函数 ...

  6. 006/搭建fabric(二)

    准备vmware虚拟机,并安装完ubuntu系统后.继续搭建fabric运行环境... 0.打开终端,切换root身份.目的:后续操作即可不用sudo... 右键->open Terminal- ...

  7. 配置OSPF认证

      按照上图拓扑配置路由器的IP 配置完后测试直连网段连通性 搭建OSPF网络 注意是多区域的配置,R2是ABR 连着area0和area1 并且每个路由器的环回接口IP也要加进去  此时密码以明文方 ...

  8. OuterXml和InnerXml

    例如 <bkk> <rp fe="few" > <fe>fff</fe> </rp> </bkk> 对于fe ...

  9. [2019杭电多校第四场][hdu6616]Divide the Stones

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6616 题意是说n个数分别为1-n,将n个数分成k堆,能否满足每堆个数相等,数值之和相等.保证n%k=0 ...

  10. 13 个设计 REST API 的最佳实践

    原文 RESTful API Design: 13 Best Practices to Make Your Users Happy 写在前面 之所以翻译这篇文章,是因为自从成为一名前端码农之后,调接口 ...