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