grep参数
- -c 显示匹配的行数(就是显示有多少行匹配了);
- -n 显示匹配内容所在文档的行号;
- -i 匹配时忽略大小写;
- -s 错误信息不输出;
- -v 输出不匹配内容;
- -x 输出完全匹配内容;
- \ 忽略表达式中字符原有含义;
- ^ 匹配表达式的开始行;
- $ 匹配表达式的结束行;
- \< 从匹配表达式的行开始;
- \> 到匹配表达式的行结束;
- [ ] 单个字符(如[A] 即A符合要求);
- [ - ] 范围 ;如[A-Z]即A,B,C一直到Z都符合要求;
- . 所有的单个字符;
- * 所有字符,长度可以为0;
- 目录ll时用-w来进行完全匹配
grep的常用命令语法
1. 双引号引用和单引号引用
在grep命令中输入字符串参数时,最好将其用双引号括起来。例如:“m y s t r i n
g”。这样做有两个原因,一是以防被误解为shell命令,二是可以用来查找多个单词组成的字符串,例如:“jet
plane”,如果不用双引号将其括起来,那么单词 p l a n
e将被误认为是一个文件,查询结果将返回“文件不存在”的错误信息。
在调用变量时,也应该使用双引号,诸如: g r e p“$ M Y VA R”文件名,如果不这样,将
没有返回结果。
在调用模式匹配时,应使用单引号.[root@mypc ]# echo `grep 123 111.txt`
(#注意是反单引号)
2. 常用的grep选项有:
-c 只输出匹配行的计数。
-i 不区分大小写(只适用于单字符)。
-h 查询多文件时不显示文件名。
-l 查询多文件时只输出包含匹配字符的文件名。
-n 显示匹配行及行号。
-s 不显示不存在或无匹配文本的错误信息。
-v 显示不包含匹配文本的所有行。
3. 特殊的——在多个文件中进行查询
$ grep
"sort"*.doc
( #在当前目录下所有. d o c文件中查找字符串“s o r t”)
$ grep "sort it"
*
(#或在所有文件中查询单词“sort it”)
接下来的所有示例是指在单个文件中进行查询
4. 行匹配
$ grep -c "48" data.f
$
4
(#g r e p返回数字4,意义是有4行包含字符串“4 8”。)
$ grep "48"
data.f
(#显示包含“4 8”字符串的4行文本)
5. 显示满足匹配模式的所有行行数:
[root@mypc oid2000]# grep -n 1234 111.txt
1:1234
3:1234ab
6. 精确匹配
[root@mypc oid2000]# grep "1234\>" 111.txt
1234
7. 查询空行,查询以某个条件开头或者结尾的行。
结合使用^和$可查询空行。使用- n参数显示实际行数
[root@mypc oid2000]# grep -n "^$"
111.txt (返回结果
2: #说明第二行是空行)
[root@mypc oid2000]# grep -n "^abc" 111.txt (#查询以abc开头的行)
[root@mypc oid2000]# grep -n "abc$" 111.txt (#查询以abc结尾的行)
8. 匹配特殊字符,查询有特殊含义的字符,诸如$ . ' " * [] ^ | \ + ? ,必须在特定字符前加\。
[root@mypc oid2000]# grep "\." 111.txt
(#在111.txt中查询包含“.”的所有行)
[root@mypc oid2000]# grep "my\.conf" 111.txt (#查询有文件名my. c o n
f的行)
9. 目录的查询
[root@mypc oid2000]# ls –l |grep
“^d” (#如果要查询目录列表中的目录)
[root@mypc oid2000]# ls –l |grep “^d[d]”
(#在一个目录中查询不包含目录的所有文件)
[root@mypc]# ls –l |grpe “^d…..x..x” (#查询其他用户和用户组成员有可执行权限的目录集合)
10.排除自身
ps -ef|grep telnet | grep -v grep
(在显示的进程中抽出“telnet”进程;并丢弃ps中的grep进程
阅读(5057) | 评论(0) | 转发(1) |