Linux 正则
一、引用自:https://www.cnblogs.com/chensiqiqi/p/6285060.html
二、grep示例
grep -i 忽略大小写
grep -w 精准匹配
grep -E 匹配正则
^(以什么开头),.*(任意字符,但不包含空格)
三、正则表达式分类
1、基本正则表达式(BRE , basic regular expression)
2、高级功能:扩展正则表达式 (ERE , extended regular expression)
3、BRE和ERE的区别仅仅是元字符的不同:
a、基本正则表达式只承认的元字符有^$.[]*其它字符识别为普通字符:\(\)
b、扩展正则表达式则添加了() {} ? + | 等
c、只有在用反斜杠""进行转义的情况下,字符() {} 才会在基本正则表达式被当做元字符处理,而扩展正则表达式中,任何元符号前面加上反斜杠反而会使其被当做普通字符来处理。
四、如何区分通配符和正则表达式
1、不需要思考的判断方法:在三剑客awk,sed,grep,egrep都是正则,其它都是通配符。
五、基础正则表达式
1、^ : ^word搜索以word开头的内容
grep "^m" aaa.test.txt
2、$ : word$搜索以word结尾的内容
grep "m$" aaa.txt
3、^$ :表示空行,不是空格
grep -n "^$" aaa.txt
4、. : 代表且只能代表任意一个字符(不匹配空行)
grep -n ".m" aaa.txt
5、\ :转义字符,让有特殊含义的字符脱掉马甲现出原形,如 \. 只表示小数点
grep -n "\.c" aaa.txt
6、* : 重复之前的字符或文本0个或多个,之前的文本或字符连续0次或多次
grep -n "q*" aaa.txt
7、.* : 任意多个字符
grep -n ".*" aaa.txt
8、^.* : 以任意多个字符串开头,.*尽可能多,有多少算多少,贪婪性
grep -n "^.*o" aaa.txt
9、括号表达式 : [abc][0-9][\.,/] : 匹配字符集合内的任意一个字符a 或 b 或 c : [a-z] 匹配所有小写字母;表示一个整体,内藏无限可能;[abc]找a或b或c 也可以写成[a-c]
grep -n "^[ade]" aaa.txt
grep -n "[abc]" aaa.txt
10、[^abc] 匹配不包含^后的任意字符a或b或c,是对[abc]的取反,且与^含义不同,若要匹配^字符,则^不能放在[]里的最前面,[ab^c]
grep -n "[^abc]" aaa.txt
grep -n "[ab^c]" aaa.txt
11、a\{n,m\} 重复前面a字符n到m次
grep "d\{2,3\}" aaa.txt
六、扩展正则表达式ERE
1、+ : 重复前一个字符一次或一次以上,前一个字符连续一个或多个,把连续的文本/字符取出
grep -E 等价于 egrep
2、? : 重复前面一个字符0次或1次(.是有且只有1个)
3、管道符 表示或者 同时过滤多个字符
netstat -anpt | grep -E "25|631"
4、() 分组过滤被括起来的东西表示一个整体(一个字符),后向引用
表示aa 或者 ab 或者ac
七、基本正则和扩展正则区别
基本正则BRE 扩展正则ERE
\? ?
\+ +
\{\} {}
\(\) ()
\
八、元字符
1、\b : 单词边界。 \bcool\b,不匹配coolant
2、\B :非单词边界。cool\B匹配coolant不匹配cool
3、\d :单个数字字符 b\db匹配b2b,不匹配bcb
4、\D :单个非数字字符 b\Db匹配bcb不匹配b2b
5、\w :单个单词字符(字母,数字与_) \w匹配1或a,不匹配&
6、\W :单个非单词字符 \W匹配&,不匹配1或a
7、\n :换行符 \n匹配一个新行
8、\s :单个空白字符 x\sx匹配x x,不匹配xx
9、\S :单个非空白字符 x\Sx匹配xkx,不匹配x x
10、\r :回车 ,\r匹配回车
11、\t : 横向制表符,\t匹配一个横向制表符
12、\v :垂直制表符,\v匹配一个垂直制表符
13、\f :换页符,\f匹配一个换页符
Linux 正则的更多相关文章
- Linux正则与文本处理工具(10)
正则表达式 (Regular Expression, RE, 或称为常规表达式)是通过一些特殊字符的排列,用于『查找/替换/删除』一行或多行文字或字符串,简单的说,正则表达式就是用在字串的处理上面的一 ...
- [svc]linux正则实战(grep/sed/awk)
企业实战: 过滤ip 过滤出第二行的 192.168.2.11. eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 ine ...
- Linux正则和grep命令
设置命令的默认参数和别名 每次都要输入 ls -l ,烦不烦,我想用 ll 来表示 ls -l, 可以,只要在 ~/.bashrc 中加上 alias ll='ls -l' ,然后运行 source ...
- 最全的三剑客和linux正则符号讲解
第2章 linux符号系列与三剑客 194 2.1 特殊符号系列 194 2.1.1 普通符号系列 194 2.1.2 引号符号系列 196 2.1.3 定向符号 197 ...
- [svc]linux正则及grep常用手法
正则测试 可以用sublime等工具快速的检测正则是否合适 china : 匹配此行中任意位置有china字符的行 ^china : 匹配此以china开关的行 china$ : 匹配以china结尾 ...
- linux正则
正则表达式 分两类: 基本正则表达式:BRE 扩展正则表达式:ERE :grep -E, egrep 正则表达式引擎: 采用不同算法,检查处理正则表达式的软件模块 PCRE(Perl ...
- linux正则sed实战案例详解
目录 1. 将nginx.conf中的注释全部去掉 2. 将nginx.com中每一行之前增加注释 3.要求一键修改本机的ip 4.将/etc/passwd中的root修改成ROOT 1. 将ngin ...
- linux正则转换csv文件
- Linux基础介绍【第四篇】
Linux文件和目录的属性及权限 命令: [root@oldboy ~]# ls -lhi total 40K 24973 -rw-------. 1 root root 1.1K Dec 10 16 ...
随机推荐
- emWin 使用 GUIBuilder 放置标题 TEXT 注意
@2018-7-10 13:27:16 emWin 使用 GUIBuilder 放置标题 “Scroll Compressor”,有居中显示要求,为了内容可在程序中方便更改且能达到自适应,应将其属性大 ...
- 【uoj228】 基础数据结构练习题
http://uoj.ac/problem/228 (题目链接) 题意 给出一个序列,维护区间加法,区间开根,区间求和 Solution 线段树.考虑区间开根怎么做.当区间的最大值与最小值相等时,我们 ...
- java开发爬虫Deno
java开发爬虫Deno 身为一个程序员不会两三手爬虫怎么能在行业里立足啊,这是开发中自己写的一个java爬虫的Demo,供大家参考. java爬虫的开发依赖于jsoup.jar 直接上代码 publ ...
- ELK应用之二:Kibana显示Nginx中来访客户端IP地域分布
在Kibana的visualize中显示Nginx访问日志客户端IP地域分布图 官网介绍: https://www.elastic.co/guide/en/beats/packetbeat/curre ...
- bzoj千题计划286:bzoj1226: [SDOI2009]学校食堂Dining
http://www.lydsy.com/JudgeOnline/problem.php?id=1226 关键点:一个人只能忍受 ‘紧跟’ 在他 后面的b个人比他先打到饭 dp[i][j][k] 前i ...
- amipy exampes
jupyter notebook of backtest examples using amipy amipy examples: http://nbviewer.jupyter.org/github ...
- python垃圾回收之分代回收
可参考vamei的博客和https://www.jianshu.com/p/1e375fb40506
- decimal模块
简介 decimal意思为十进制,这个模块提供了十进制浮点运算支持. 常用方法 1.可以传递给Decimal整型或者字符串参数,但不能是浮点数据,因为浮点数据本身就不准确. 2.要从浮点数据转换为De ...
- 升级openssh到最新版本
首先,下载最新版本,传到服务器:http://mirror.aarnet.edu.au/pub/OpenBSD/OpenSSH/portable/ 安装 cd /root/ mkdir ssh_upg ...
- Linux TTY驱动--Uart_driver底层【转】
转自:http://blog.csdn.net/sharecode/article/details/9196591 版权声明:本文为博主原创文章,未经博主允许不得转载. Linux 中将串口驱动进行了 ...