grep 是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
grep常用用法
[[email protected] ~]# grep [-acinv] [--color=auto] ‘搜寻字符串‘ filename 选项与参数: -a :将 binary 文件以 text 文件的方式搜寻数据 -c :计算找到 ‘搜寻字符串‘ 的次数 -i :忽略大小写的不同,所以大小写视为相同 -n :顺便输出行号 -v :反向选择,亦即显示出没有 ‘搜寻字符串‘ 内容的那一行! --color=auto :可以将找到的关键词部分加上颜色的显示喔!
1、将filename中包含w的行输出来
[[email protected] log]# grep w filename wo ai wo jia wo hen hao da jia hao wo shi yi ge hao ren
2、把行号显示出来
[[email protected] log]# grep -n w filename 1:wo ai wo jia 3:wo hen hao 4:da jia hao wo shi yi ge hao ren
3、有多少行含有匹配的模式
[[email protected] log]# grep -c wo filename 3
4、与正则表达式结合
字符类的搜索:搜寻 test 或 taste 这两个单字, [] 里面不论有几个字节,他都谨代表某『一个』字节
[[email protected] log]# grep t[ae]st filename test is meng tast is huan
反向搜索-- 字符类的反向选择 [^] :如果想要搜索到有 oo 的行,但不想要 oo 前面有 g,如下
[[email protected] log]# grep -n ‘[^g]oo‘ filename 8:root is a super
行首与行尾字节 ^ $
注意:
^ 符号,在字符类符号(括号[])之内与之外是不同的! 在 [] 内代表『反向选择』,在 [] 之外则代表定位在行首的意义!
只要行首是wo的行
[[email protected] log]# grep -n ^wo filename 1:wo ai wo jia 3:wo hen hao
找出空白行----只有行首跟行尾 (^$)
[[email protected] log]# grep -n ‘^$‘ filename 6: 9: 10:
任意一个字节 . 与重复字节 *
这两个符号在正则表达式的意义如下:
. (小数点):代表『一定有一个任意字节』的意思; * (星号):代表『重复前一个字符, 0 到无穷多次』的意思,为组合形态
[[email protected] log]# grep -n ‘g..d‘ filename
8:good is a gread
时间: 2024-11-09 00:03:23