grep命令的作用,是在指定的文件中,搜索符合条件的字符串。
命令格式:
[root@localhost ~ ] # grep [选项] ”搜索内容” 文件名 选项:
-A 数字:列出符合条件的行,并列出后续的n行。-B 数字:列出符合条件的行,并列出前面的n行。-c:统计找到的符合条件的字符串的次数。-i:忽略大小写。-n:输出行号。-v:反向查找。--color=auto:搜索出的关键字用颜色显示。示例:
/etc/passwd中,有多少可以登录的用户。 [root@localhost ~]# grep "/bin/bash" /etc/passwd /etc/passwd中,包含有root的行,并列出后续的3行。 [root@localhost ~]# grep -A 3 "root" /etc/passwd /etc/passwd中,可以登录的用户,并显示行号。 [root@localhost ~]# grep -n "/bin/bash" /etc/passwd /etc/passwd中,不含有/bin/bash的行,其实就是列出所有的伪用户。 [root@localhost ~]# grep -v "/bin/bash" /etc/passwd find命令是在系统当中搜索符合条件的文件名,搜索时文件名是完全匹配。如果需要模糊查询,使用通配符进行匹配。
#建立文件abc [root@localhost ~ ] # touch abc #建立文件abcd [root@localhost ~ ] # touch abcd #查找abc文件 [root@localhost ~ ] # find . -name ”abc" ./abc 搜索文件名是abc的文件,只会找到abc文件,而不会找到文件abcd。虽然abed文件名中包含abc,但是find命令是完全匹配,只能和要搜索的数据完全一样,才能找到。
注意:
find命令是可以通过-regex选项识别正则表达式规则的,也就是说find命令可以按照正则表达式规则匹配,而正则表达式是模糊匹配。但是对于初学者而言,find命令和grep命令本身就不好理解,所以我们这里只按照通配符规则来进行find查询。
grep命令是在文件当中搜索符合条件的字符串,如果需要模糊查询,使用正则表达式进行匹配,搜索时字符串是包含匹配。
#在test文件中写入abc数据 [root@localhost ~ ] # echo abc > test #在test文件中再追加abcd数据 [root@localhost ~]#echo abcd >> test #在test文件中查找abc字符串 [root@localhost ~]#grep”abc" test abc abcd grep命令查找时,只要数据行中包含有abc,就会都列出,所以abc和abed都可以查询到。
管道符之前总结过,请看之前的文章:https://www.cnblogs.com/liuyuelinfighting/p/15530010.html。
我们下面简单的做几个练习:
[root@localhost ~]# netstat -an | grep "ESTABLISHED" wc命令统计行数。 [root@localhost ~]# netstat -an | grep "ESTABLISHED" | wc -l 通配符是用来匹配文件名的,文件名在查询的时候是完全匹配的,必须一模一样才会查询出,否则就要加通配符,进行模糊查询。

练习:
# 创建4个测试文件 [root@localhost tmp]# touch abc [root@localhost tmp]# touch abcd [root@localhost tmp]# touch 012 [root@localhost tmp]# touch 0abc # “*”代表查找所有的文件 [root@localhost tmp]# ls * 012 0abc abc abcd # “?"匹配任意一个字符,所以会匹配0abc #但是不能匹配abc,因为“?”"不能匹配空 [root@localhost tmp]# ls ?abc 0abc # 匹配任何以数字开头的文件 [root@localhost tmp]# ls [0-9]* 012 0abc # 匹配不已数字开头的文件 [root@localhost tmp]# ls [^0-9]* abc abed
上一个:C++引用以及结构体