Linux bash 正则表达式
[:alnum:]代表英文大写字母及数字
[:alpah:]代表英文大小写字母
[:blank:]代表空格和 tab 键
[:cntrl:]键盘上的控制按键,如 CR,LF,TAB,DEL
[:digit:]代表数字
[:graph:]代表空白字符以外的其他
[:lower:]小写字母
[:print:]可以被打印出来的任何字符
[:punct:]代表标点符号
[:upper:]代表大写字符
[:space:]任何会产生空白的字符如空格,tab,CR 等
[:xdigit:]代表 16 进位的数字类型
grep -n '[[:lower:]]' test.txt 文本中的小写高亮显示
grep -n '[[:digit:]]' test.txt 文本中的数字高亮显示
grep 命令:
参数说明:
-a :将 binary 档案以 text 档案的方式搜寻数据
-c :计算找到 '搜寻字符串' 的次数
-i :忽略大小写的不同,所以大小写视为相同
-n :顺便输出行号
-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行!
grep -n 'the' test.txt
grep -in'the' test.txt
字符组匹配:
[]中包含的任意一个字符。只能是一个。
字符组支持由连字符“ - ”来表示一个范围。当“ - ”前后构成范围时,要求前面字符的码位小于后面字符的码位。
[^...] 排除型字符组。排除后面的字符。
[abc] :表示“a”或“b”或“c”
[0-9] :表示 0~9 中任意一个数字,等价于[0123456789]
[\u4e00-\u9fa5] :表示任意一个汉字
[^a1<] :表示除“a”、“1”、“<”外的其它任意一个字符
[^a-z] :表示除小写字母外的任意一个字符
^ 与行尾符: $
'^[A-Z]' 表示以大写字母开头。
'[^A-Z]' 表示除了大写字母 A-Z 的所有字符。
'^$' : 过滤掉空白行
'^#' :过滤掉注释行(以#号开头)
grep -n '^#' test.txt 首部匹配#
grep -n '[^#]' test.txt 不匹配#
grep -n '^$' test.txt 匹配空行
任意一个字符: " . "(小数点)与重复字符 “ * ”(星号)
grep -n 'a.ou.' test.txt
*(星号):代表重复前面 0 个或者多个字符。
e*: 表示具有空字符或者一个以上 e 字符。
ee*,表示前面的第一个 e 字符必须存在。第二个 e 则可以是 0 个或者多个 e 字符。
eee*,表示前面两个 e 字符必须存在。第三个 e 则可以是 0 个或者多个 e 字符。
ee*e :表示前面的第一个与第三个 e 字符必须存在。第二个 e 则可以是 0 个或者多个 e 字符。
grep -n 'e*' test.txt 有空行的存在,所以打印出全文
grep -n '@*' test.txt 有空行的存在,所以打印出全文
grep -n 'eee*' test.txt
限定连续字符范围{ }:
{ }可限制一个范围区间内的重复字符数。举个例子,若要找出 2~5 个 o 的连续字符串,如何做? 此时便要用到{}了。由于 { 与 } 在 shell 中有特殊意义,需要用到转义字符\。
rep -n 'o\{2\}' test.txt 查找连续的两个 o 字符,与命令 grep -n 'ooo*' test.txt 的结果相同。
查找 g 后面接 2 到 5 个 o,然后再接 g 的字符串
grep -n 'go\{2,5\}g' test.txt
总结:
^word 表示带搜寻的字符串(word)在行首
word$ 表示带搜寻的字符串(word)在行尾
.(小数点) 表示 1 个任意字符
\ 表示转义字符,在特殊字符前加\会将特殊字符意义去除
* 表示重复 0 到无穷多个前一个 RE(正则表达式)字符
[list] 表示搜索含有 list 的字符串
[n1-n2] 表示搜索指定的字符串范围,例如[0-9] [a-z] [A-Z]等
[^list] 表示反向字符串的范围,例如[^0-9]表示非数字字符,[^A-Z]表示非大写字符范围
\{n,m\} 表示找出 n 到 m 个前一个 RE 字符
\{n,\} 表示 n 个以上的前一个 RE 字符
sed概述:
sed 是非交互式的编辑器。它不会修改文件,除非使用 shell 重定向来保存结果。默认情况下,所有的输出行都被打印到屏幕上。
sed 编辑器逐行处理文件(或输入),并将结果发送到屏幕。具体过程如下:首先 sed 把当前正在处理的行保存在一个临时缓存区中(也称为模式空间),然后处理临时缓冲区中的行,完成后把该行发送到屏幕上。sed 每处理完一行就将其从临时缓冲区删除,然后将下一行读入,进行处理和显示。处理完输入文件的最后一行后,sed 便结束运行。sed 把每一行都存在临时缓冲区中,对这个副本进行编辑,所以不会修改原文件。
如果要修改原文件,可使用-i 选项。
将 test.txt 的内容列出并打印行号,同时,将 2-5 行删除显示
nl test.txt | sed '2,5d' sed 是 sed -e 的简写, 后接单引号
nl test.txt | sed '2d' 删除第 2 行
nl test.txt | sed '3,$d' 删除第三行到最后一行, $定位到最后一行
sed -i '1d' test.txt 在原文件中删除第 1 行
a表示在行后加上字符串,i表示在行前添加字符串
nl test.txt | sed '2a test' 第二行后添加 test 字符串
nl test.txt | sed '2i test' 第二行前添加 test 字符串
nl test.txt | sed '2a test\ntest' 第二行后加入两行 test,“\n”表示换行符
将 2-5 行内容取代为 No 2-5 number
c 为替换内容选项
nl test.txt | sed '2,5c No 2-5 number'
列出 test.txt 内第 5-7 行
sed 命令中-n 为安静模式选项。以下两条命令执行结束后可对比结果
nl regular_express.txt |sed -n '5,7p' 只显示5-7行
nl regular_express.txt |sed '5,7p' 5-7行双倍显示
替换字符串:
sed 's/被替换字符串/新字符串/g'
获取本机 IP 的行
/sbin/ifconfig eth0 | grep 'inet ' inet 后面的空格不能少, 在/sbin/ifconfig eth0 的结果中查找‘inet’,打印至终端
IP 前面的部分予以删除,下面两条命令结果相同。
/sbin/ifconfig eth0 | grep 'inet '| sed 's/.inet...://g'
/sbin/ifconfig eth0 | grep 'inet '| sed 's/.\{0,9\}://g'
IP 后面的部分删除
/sbin/ifconfig eth0 | grep 'inet '| sed 's/.inet...://g' | sed 's/..:.*$//g'
/sbin/ifconfig eth0 | grep 'inet '| sed 's/.inet...://g' | sed 's/.\{0,3\}:.*$//g'
扩展正则表达式
grep -v '^$' test.txt |grep -v '^#'
egrep -v '^$|^#' test.txt
+ :表示重复一个或一个以上的前一个 RE 字符
grep -n 'goo*d' test.txt
egrep -n 'go+d' test.txt
? : 表示重复零个或一个前一个 RE 字符
egrep -n 'go?d' test.txt
| :表示用或的方式找出数个字符串
egrep -n 'gd|good' test.txt
() : 表示找出群组字符串
egrep -n 'g(la|oo)d' test.txt 也就是搜寻(glad)或 good 这两个字符串
()+ : 多个重复群组判别
echo'AxyzxyzxyzxyzC' | egrep 'A(xyz)+C'
echo'AxyzxyzxyzxyzC' | egrep 'A(xz)+C'
也就是要找开头是 A 结尾是 C 中间有一个以上的 ‘xyz’ 或 ‘xz’ 字符串的意思。
结果显示 ‘A(xyz)+C’ 可以匹配, ‘A(xz)+C’ 没有匹配项。
评论