linux正则表达式和正则表达式的一些命令

    正则表达式是处理一批繁杂的数据,做到快速搜索,快速匹配,快速替换删除等功能的一种需求。常用正则表达式的命令有grep,sed,awk(三剑客)vi,egrep。其中egrep和awk还支持扩展的正则表达式。

    下面先介绍一下这些命令。vi和vim在以后介绍。



     grep:

          -v:排除匹配内容。

          -i:忽略大小写。

          -o:只输出匹配内容。

          -n:在行首显示行号。

          -e:扩展的正则表达式(=egrep)。

          --color=auto:支持颜色。



     sed:输出时既输出匹配内容,还要把源内容原封不动得输出。

          s: 替换。(格式  s/source string/replace string/)

          g: 全局。一般与s一起用。(s/source string/replace string/g)

          p:  打印。可以和sg一块使用(s/source string/replace string/gp)

          w file: 保存至file文件中。

          d:删除。

          a: 追加。

          i:在前面插入。

          c: 修改。

          y: 按字符转换。

          -f script-file:运用script-file来运行file文件。(格式:sed -f sed.sh test.txt)

          -n:静默模式输出。(只输出匹配内容)

          -i: 修改源文件。

          -r: 支持扩展正则。



   正则表达式技术:

              . :任意单个字符。

              * :匹配前面的字符零次或多次。

              .*:匹配任意多个字符。

              []:匹配[]内任意单个字符。

              ^ :匹配字符串的行首。

              $ :匹配字符串的行尾。

              ^$:空白行。

              \{m,n\}:匹配前面字符重复m-n次。

              \{m,\}:匹配前面的字符重复至少m次。

              \{,n\}:匹配前面的字符重复最多n次。

              其中,\{\}对于扩展的正则表达式使用{}。

              \(string\) 和\n :\n(使用\1,\2...\9)是string的内容。

   扩展的正则表达式:

              + : 重复前面的字符一次货多次。

              ?:重复前面的字符零次或一次。

              | : 匹配|前面或后面的字符。

             ():匹配正则集合。

              {m,n}:重复前面的字符m-n次。

              posix:[]内的字符集:

              [:alpha:] 字母           [:blank:] 空格或Tab字符

              [:digit:] 数字           [:upper:] 大写字母

              [:punct:] 标点符号       [:lower:] 小写字母

              [:space:] 空白字符       [:alnum:] 字母或数字字符

              




       



         



郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。