linux的命令行可以胜任所有的工作,这和ms的产品有着很大的区别,到现在为止仍然有很多的爱好者对敲键盘乐此不疲,而在繁重的管理工作和键盘工作中,正则表达式对于简化工作起到了很大的作用。
Perl regular expressions man page.
http://www.perldoc.com/perl5.8.0/pod/perlre.html
一、正则表达式简介
事实上,正则表达式不仅适用于linux,多种编程语言中也可以使用到它,因为它实际上是人们对于某种规律的表达方式。
如果要把他的所有应用都讲上的话那这篇文章会变的太长以至于无法阅读,我只介绍他在linux下和几种最重要的命令的搭配使用。
基本的元字符集:
^行首
$行尾
*匹配星号前的字符一次或多次
[]匹配[]内的字符,可以是一个字符也可以是字符列
/用来屏蔽一个元字符的特殊含义,可以使其失去原有的意义。
pattern/{n/}用来匹配前面pattern出现的次数。n为次数。
而其中使用最多的是行首和行尾,无论在任何地方都可能会用到它们,比如vi,你输入$,就可以跳到行尾,在bbs上,你也可以输入$,直接跳到这个版的最后的一篇文章。
后面所说的将是他们的和具体命令结合的例子。
二、grep 和正则表达式
grep是个非常常用的工具,linux其实和internet一样,都是一个充满了大量信息、数据的东西,如何有效的过滤自己不用的信息、获取有用的信息反映了一个人水平的高低,当我还是linux新手的时候还不懂得用grep呢。
一个最简单的应用例子就是如何查看一个目录里只查看文件夹了,ls并没有提供这样的参数给你,而是需要你用grep(或后面提到的awk)来实现这样的功能。我们知道一个文件夹的属性为dxxx,所以我们可以用ls -l |grep ^d,即打印匹配行首第一个字母为d的项目,这样就把所有的文件夹打印出来而忽略其他非文件夹的文件了,举一反三,我们可以用来匹配所有的权限,比如我想找到所有权限为rwx------的文件,这样我们就可以输入ls -l|grep ^.rwx,其中.号为匹配任意一个字符。再看下面的例子,想找权限为----rw----的文件,可以使用ls -l|grep ^....rw....,怎么样,这样简单多了吧,我们还可以寻找所有以*号结尾的文件(在某些linux上用它来代表可执行文件)即ls |grep /*$,要注意的是必须加/以屏蔽*号的原来的特殊意义,而$号是加在行尾的。
可以用^符号来再非正则表达式的意思(即否定)如前面我说了要看文件夹,那么如果我想看不是文件夹的文件怎么办 : ls -l|grep ^[^d],这样的意思就是说查看所有行首不为d字母的项,当然也可以用grep 的-v选项实现同样功能。不过今天重点是说正则表达式,所以就不讲参数了。
我还可以查找多个文件,如有一个目录里面有我需要的内容,我只知道他在某个.doc文件里头,我可以用grep "表达式" *.doc,而这个表达式就需要你去想了,有多种方法可以指定模糊的表达式,如k...D,代表以小写字母k开头,中间三个是任意字符而以大写字母D结尾的字符串,而k*D,则表达以k开头中间可以是任意长度任意字符的而以D结尾的字符串,还可以用[]指定范围,如[12345]day,指的是以1到6中任意一个字符开头后面是day的字符串,像3day就匹配这个表达式而13day就不匹配。[Ss]可以指定以大写S或者小写s的字符,而像结合pattern/{n/}还可以用更奇妙的用法,我就不多说了。
三、awk和正则表达式
awk对于从大的数据文件中抽取指定的数据包十分有用,比如你可以用他来管理passwd文件,或者是日志文件(相当巨大的文件,而用了awk就会变的很轻松了),通常awk都是和grep结合来用的,又grep抽出行,再有awk抽出行中指定的列,不过就算单独用awk也一样好用。请看看这样的例子
awk -F: '{if($6 ~ /bash/) print $0}' /etc/passwd
这是个相当复杂的例子,我举这个例子的目的只是为了说明结合命令语法和正则表达式可以实现相当强的过滤作用,这个命令的作用是从passwd文件中的第六列中抽取所有含有bash的项目然后在打印这些项目的第一项即他们的用户名。我假设passwd为这样的内容
root:*:*:*:*:*:/bin/bash
user:*:*:*:*:*:/bin/bash
xie:*:*:*:*:*:/bin/csh
ftp:*:*:*:*:*:/bin/zsh
那么输出就应该为
root
user
我们逐个来分析,首先 -F:指定:为分隔符,因为默认的分隔符是空格,然后我们用一个假设语句,因为假设语句和后面的print组合成一个动作,所以必须用花括号括起来,意思是如果(if)第六列($6)匹配(~)字符串bash,那么打印(print)第零列($0)。其中/bash/指的是匹配bash,//只是起括起来的作用,并不参与判断。
awk有自己的正则表达式和条件操作符,他比一般的正则表达式要多出两个元字符,就是+和?,+使用匹配一个或多个字符。?匹配模式出现频率,例如使用/XY?Z/匹配XYZ,或YZ。条件操作符有
<小于
<=小于等于
==等于(这个和C语言是一样的)
!=不等于
>=大于等于
~匹配正则表达式
!~不匹配正则表达式
结合以上表达式,还可以作出更多的动作,如
ls -l|awk 'BEGIN {print "Name/t SIZE"} {if /^[^d]/} {print $9 "/t" $5} {tot+=5} END {print "total KB:"tot}'
可以用此表达式来打印文件名几其长度,然后输出所有文件加起来的大小。
他相当与于我前面所说的先找出不是文件夹的文件,然后打印他们的大小和长度,把这些大小值放入变量tot中,放一次加一次(+=),最后打印tot,就可以把所有文件的大小求出来了。
逻辑符号
&& AND,必须同时为真
! 非,求逆
awk '{if ($3=="root" && $5="/root") print $0}' /etc/passwd
当组和个人目录都为root的时候打印用户的名字。
嘿嘿,事实上awk还有算术操作符呢,我为了偷懒就不写了,不过上面已经有例子了(用了+=),就留给大家慢慢研究吧。
四、VI和正则表达式
文书编辑更加用用到正则表达式了,比如说在编辑状态下输入^,可以跳到行中第一个非空字符,输入$,可以跳到本行行尾(在行号表示的时候,$代表最后一行)。输入/可以搜索字符串,同样可以使用正则表达式匹配,如/^str,则匹配行首的str,输入/str$,则匹配行尾的str。其他的和正则表达式方法一样。
五、总结
linux还有更复杂的sed也会用到正则表达式,事实上大部分和信息过滤有关的都离不开他,不过小子才疏学浅,实在是写不了了,仅以此文抛砖引玉,不过各位大侠可千万别因为我这篇文章写的差而全把砖头往我招呼啊……
还有一点是给初学者的:记得多用|管道和文件操作符啊,0代表标准输入、1代表标准输出、2代表错误输出,其他还有3-9你是可以任意使用的,如可以先把某文件指到操作符4,再把4指向0,那么就可以作为程序的输入了。
http://blog.chinaunix.net/u/31547/showart_350800.html
分享到:
相关推荐
javascript中正则表达式用法详解
下面,我们将深入探讨C#中正则表达式的运用,并通过实例解析其工作原理。 1. 正则表达式基础 - 定义:正则表达式是由特殊字符(元字符)和普通字符组成的字符串,用来描述一种字符串模式。 - 元字符:例如 `.` ...
JAVA中正则表达式详解
VBA正则表达式在Excel中使用,希望能给大家有所帮助,还有其他相关EXCEL资源,需要有的可以联系我. 谢谢.
javascript中正则表达式实现输入内容过滤
### ABAP中正则表达式的简单使用 #### 1. **匹配所有字符** 在ABAP中,可以使用`[^x00-xff]*`这样的正则表达式来匹配所有字符,其中`[^x00-xff]`表示除了ASCII控制字符之外的所有字符,而`*`则表示可以匹配任意...
javascript中正则表达式反向引用示例介绍.doc
正则表达式是编程语言中的一种强大工具,用于处理字符串,尤其在数据验证、文本搜索和替换等方面。在Java中,正则表达式是通过`java.util.regex`包中的类来实现的,如`Pattern`和`Matcher`。下面将详细介绍正则...
### PHP中的正则表达式应用详解 在PHP编程中,正则表达式是一种...以上是关于PHP中正则表达式的详细解析与实际应用案例。通过学习和理解这些正则表达式,你可以更高效地处理各种文本数据,提高程序的功能性和健壮性。
通过本文的学习,读者应该能够理解正则表达式的基本概念,掌握Python中正则表达式库re的使用,并能够将正则表达式应用到实际的文本处理问题中。 本文不仅介绍了正则表达式的使用技巧和实际应用,还讨论了性能优化和...
JAVA中正则表达式的一个简单例子.pdf
### 浅谈Java中正则表达式的优化方法 在日常的软件开发过程中,正则表达式作为一种强大的文本处理工具被广泛应用于数据验证、文本搜索与替换等场景之中。尤其是在Java语言环境中,`java.util.regex`包提供了丰富的...
java中正则表达式Pattern类的应用,基本上用来验证之类的应用
在Java中,正则表达式是一种强大的文本处理工具,用于匹配、查找、替换和分割字符串。...在实际开发中,可以根据需求选择合适的正则表达式和匹配标志,灵活运用`Pattern`和`Matcher`类,实现高效的数据处理。
本文主要介绍了关于Oracle中正则表达式的使用方法,下面话不多说了,来一起看看详细的介绍。 Oracle使用正则表达式离不开这4个函数:regexp_like、regexp_substr、regexp_instr、regexp_replace。 regexp_like 该...
本篇将深入探讨Objective-C中正则表达式的使用,特别是涉及到特殊符号转义字符的处理。 在Objective-C中,我们通常使用NSRegularExpression类来操作正则表达式。首先,我们需要了解一些基础的正则表达式语法,比如...
C#__IsMatch中正则表达式的用法 C#__IsMatch中正则表达式的用法,可以通过两种方法来实现:一种是在文本输入框后加入正则表达式验证控件 RegularExpressionValidator,这种方法适用于 WebForm 中;另一种是在隐藏...
javascript中正则表达式及匿名函数相结合的典型应用 通过一个小例子详细说明和介绍了在javascript中如何应用正则表达式,以及在什么时候下可以应用匿名函数。 并介绍了如何将这两种结合在一起。 实例代码简洁清晰,...