grep
grep的主要作用就是文本过滤,在Linux中还是很好用的,自我感觉学这个是很有意思的,也很有用,刚学的时候可能会感觉它的用法很简单,但是再往后学习,你会喜欢上这个命令的,因为它确实很方便,很强大,好好学习,细细品味,相信你会对grep这个强大的命令有更深刻的理解。下面介绍一下它的基本语法
Global search REgular expression and Print out the line
(全局搜索正则表达式和打印行)
作用:文本搜索工具,根据用户指定的“模式”对目标文件逐行进行匹配检查,打印匹配到的行
模式:由正则表达式字符及文本字符所编写的过滤条件
语法:grep [OPTIONS] PATTERN [FILE...]
例如:
grep root /etc/passwd
grep `whoami` /etc/passwd
grep "$USER" /etc/passwd
选项:
-i : 忽略字符大小写
-o : 仅输出匹配到的字符串
-v : 显示不被匹配到的行
-n : 显示匹配到的行号
-c : 显示匹配到的行数
-w : 显示匹配到的整个单词
-e : 实现多个选项之间的逻辑或or关系
-AN# : 显示匹配到的字符串#和之后的N行
-BN# : 显示匹配到的字符串#和之前的N行
-CN# : 显示匹配到的字符串#和它前后各N行
看了上面的介绍可能也不知道grep有哪些特别的地方,但是学完正则表达式,你会感觉grep和正则表达式在一起用真的好方便,功能很强大。虽然正则表达式刚开始学起来会有点晕,但是课下做点题,多动脑思考,相信你会有很大的收获的。下面不只是要记住,而且会用哦
正则表达式
1、 程序支持:grep,sed,awk,vim,less,nginx等
2、分两类:
基础正则表达式:BRE
扩展正则表达式:ERE
3、元字符(有特殊含义的字符)分类:
字符匹配、匹配次数、位置锚定、分组
4、使用man 7 regex可查看正则表达式的内容
《1》 字符匹配的正则表达式元字符:
. 匹配单个任意字符
[] 匹配指定范围内的任意单个字符
[^] 匹配指定范围外的任意单个字符
[:alnum:] 字符和数字
[:alpha:] 代表任何英文大小写字符
[:lower:] 小写字母
[:upper:] 大写字母
[:blank:] 空白字符(空格和制表符)
[:space:] 水平和垂直的空白字符(比[:blank:]的范围广)
[:cntrl:] 不可打印的控制字符(退格、删除)
[:digit:] 十进制数字
5.正则表达式
《1》:匹配次数:用在要指定的字符后面,用于指定前面的字符要出现的次数。贪婪模式:尽可能长地匹配
* : 匹配前面的字符任意次,包括0次
.* : 匹配任意长度的任意字符
\? : 匹配前面的字符0次或一次,需要加引号引起来。
\+ : 匹配前面的字符至少一次
\{n\} : 匹配前面的字符n次
\{m,n\} : 匹配前面的字符最少m次,最多n次
\{n,\} : 匹配前面的字符最多n次
\{,n} : 匹配前面的字符最少n次
2、位置锚定
^ : 行首锚定,用于模式最左侧
$ : 行尾锚定,用于模式最右侧
^PATTERNS : 用户模式匹配整行
^$ : 空行
^[[:space:]]*$ : 空白行,有Tab空格的行
\< : 用于词首锚定,用于单词模式的左侧
\> : 用于词尾锚定,用于单词模式的右侧
\<PATTERN\> : 用于匹配整个单词
3.分组\(\)将一个或多个字符捆绑在一起,当做一个整体来处理:
例如:\(root\)\+
分组括号中的模式匹配到的内容会被正则表达式引擎记录内部的变量中,
这些变量的命名方式为: \1, \2, \3, ...
\1 表示从左侧起第一个左括号以及与之匹配括号之间的模式所匹配到的
字符:
示例:\(string1\+\(string2\)*\)
\1 :string1\+\(string2\)*
\2 :string2
上面一大堆零碎的看起来确实有些头疼,但是不要刻意去死记硬背,做做下面的小练习,使用这些知识,相信在做题的时候你会掌握不少
练习:
1、显示/proc/meminfo文件中以大小s开头的行(要求:使用两
种方法)
2、显示/etc/passwd文件中不以/bin/bash结尾的行
3、显示用户rpc默认的shell程序
4、找出/etc/passwd中的两位或三位数
5、显示CentOS7的/etc/grub2.cfg文件中,至少以一个空白字符开头的且后面存非空白字符的行
6、找出“netstat -tan”命令的结果中以‘LISTEN’后跟任意多个空白字符结尾的行
7、显示CentOS7上所有系统用户的用户名和UID
首先要知道系统用户ID是 0-999 的哦
8、添加用户bash、testbash、basher、sh、nologin(其shell为/sbin/nologin),找出/etc/passwd用户名同shell名的行
9、利用df和grep,取出磁盘各分区利用率,并从大到小排序
一般都不会想到要过滤一下/dev/sda 这样的真正是磁盘分区的,所以下面的写法还是比较符合题意的
下面这个用到了正则表达式,而且思路也挺好,值得借鉴
做完这些题相信你一定会有很大的进步,也有了一定的感悟,所以这些知识点还是需要在不断地应用过程中消化理解,才能熟练掌握。