grep

grep的主要作用就是文本过滤,在Linux中还是很好用的,自我感觉学这个是很有意思的,也很有用,刚学的时候可能会感觉它的用法很简单,但是再往后学习,你会喜欢上这个命令的,因为它确实很方便,很强大,好好学习,细细品味,相信你会对grep这个强大的命令有更深刻的理解。下面介绍一下它的基本语法

  Global search REgular expression and Print out the line  (全局搜索正则表达式和打印行)
  作用:文本搜索工具,根据用户指定的“模式”对目标文件逐行进行匹配检查,打印匹配到的行  
  模式:由正则表达式字符及文本字符所编写的过滤条件  
  语法:grep [OPTIONS] PATTERN [FILE...]    
     eg: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》:位置锚定        
          ^   行首锚定,用于模式最左侧     
          $   行尾锚定,用于模式最右侧      
       ^PATTERN$  用户模式匹配整行     
        ^$      空行      
    [[: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结尾的行

正则表达式的用法_文本过滤_02


3、显示用户rpc默认的shell程序

正则表达式的用法_Linux_03


4、找出/etc/passwd中的两位或三位数

正则表达式的用法_Linux_04


5、显示CentOS7的/etc/grub2.cfg文件中,至少以一个空白字符开头的且后面存非空白字符的行

正则表达式的用法_工具_05


6、找出“netstat -tan”命令的结果中以‘LISTEN’后跟任意多个空白字符结尾的行

正则表达式的用法_Linux_06


7、添加用户bash、testbash、basher、sh、nologin(其shell为/sbin/nologin),找出/etc/passwd用户名同shell名的行

正则表达式的用法_工具_07


8、显示CentOS7上所有系统用户的用户名和UID

首先要知道系统用户ID是 0-999 的哦

正则表达式的用法_Linux_08


9、利用df和grep,取出磁盘各分区利用率,并从大到小排序

一般都不会想到要过滤一下/dev/sda 这样的真正是磁盘分区的,所以下面的写法还是比较符合题意的

正则表达式的用法_工具_09


下面这个用到了正则表达式,而且思路也挺好,值得借鉴

正则表达式的用法_文本过滤_10


做完这些小练习是不是感觉自己进步很大,所以学习Linux是一件很有意思的事,只要你认真、用心,相信你会收获很多的!