• 正则表达式


    正则表达式用来在文件中匹配符合条件的字符串,正则是包含匹配。grep、awk、sed等命令可以支持正则表达式。
    通配符用来匹配符合条件的文件名,通配符是完全匹配。ls、find、cp这些命令不支持正则表达式。

    * :前一个字符匹配0次或任意多次。
    . :匹配除了换行符外任意一个字符。
    ^ :匹配行首。例如:^hello会匹配以hello开头的行。
    $ :匹配行尾。例如:hello$会匹配以hello结尾的行。
    [] :匹配中括号中指定的任意一个字符。[0-9]匹配任意一位数字,[a-z][0-9]匹配小写和一位数字构成的两位字符。
    [^] :匹配除中括号以外任意一个字符例如:[^0-9]匹配任意一位非数字字符 [^a-z]匹配任意一位非小写字母。
    :转义符。取消字符的特殊含义。
    {n} :前面的字符恰好出现n次。例如:[0-9]{4}匹配4位数字。
    {n,} :前面的字符出现不小于n次。例如:[0-9]{2,}表示两位及以上的数字。
    {n,m}:前面的字符至少出现n次,最多出现m次,例如:[a-z]{6,8}匹配6到8位的小写字母。

    举例:
    grep "a*" test.txt :匹配所有内容,包括空白行
    grep "aa*" test.txt :匹配至少包含一个a的行
    grep "aaa*" text.txt :匹配至少包含两个连续a的字符串
    grep "aaaaa*" text.txt:匹配至少包含4个连续a的字符串

    grep "s..d" text.txt :匹配s和d之间有两个字符的字符串
    grep "s.*d" text.txt :匹配s和d之间有任意字符的字符串
    grep ".*" text.txt :匹配任意字符串

    grep "^M" text.txt :匹配以M开头的行
    grep "n$" text.txt :匹配以n结尾的行
    grep -n "^$" text.txt :匹配空白行

    grep "s[ao]id" text.txt :匹配s和i之间要么是a要么是o
    grep "[0-9]" text.txt :匹配任意一个数字
    grep "^[a-z]" text.txt :匹配用小写字母开头的行

    grep "^[^a-z]" text.txt :匹配不用小写字母开头的行
    grep "^[^a-zA-Z]" text.txt :匹配不用字母开头的行

    grep ".$" text.txt :匹配使用"."结尾的行

    grep "a{3}" text.txt :匹配a字母连续出现三次的字符串
    grep "[0-9]{3}" text.txt :匹配包含连续的三个数字的字符串
    grep "^[0-9]{3,}[a-z]" text.txt :匹配最少用连续3个数字开头的行
    grep "sa{1,3}i" text.txt :匹配在字母s和字母i之间有最少1个a,最多3个a

  • 相关阅读:
    Python参考资料汇总
    Redis发布/订阅
    Redis读书笔记之API的理解和使用
    三、Dubbo源码学习笔记(一)之 Spring容器启动
    利用VMware在虚拟机上安装Zookeeper集群
    二、Dubbo相关文献链接
    一、Dubbo初体验
    @Retention小记
    EasyUI知识点杂记
    ---Mybatis3学习笔记(2)补充
  • 原文地址:https://www.cnblogs.com/javasl/p/11155145.html
Copyright © 2020-2023  润新知