正则表达式和grep命令的用法

前端之家收集整理的这篇文章主要介绍了正则表达式和grep命令的用法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

一、@H_502_4@@H_502_4@正则表达式:@H_502_4@

正则表达式(或称@H_502_4@Regular Expression,简称@H_502_4@RE)就是由普通字符(例如字符@H_502_4@ a 到@H_502_4@ z)以及特殊字符(称为元字符)组成的文字模式。@H_502_4@

该模式描述在查找文字主体时待匹配的一个或多个字符串。@H_502_4@

正则表达式作为一个模板,将某个字符模式与所搜索的字符串进行匹配。简单的说,正则表示式就是处理字符串的方法,它是以行为单位来进行字符串的处理行为,@H_502_4@ 正则表示式通过一些特殊符号的辅助,可以让使用者轻易的达到搜寻@H_502_4@/删除@H_502_4@/取代某特定字符串的处理程序。@H_502_4@vim、@H_502_4@grep、@H_502_4@find、@H_502_4@awk、@H_502_4@sed等命令都支持正则表达式。@H_502_4@

常用正则表达式:@H_502_4@

1、@H_502_4@.@H_502_4@代表任意单个字符@H_502_4@,如:@H_502_4@/l..e/与包含一个@H_502_4@l,后跟两个字符,然后跟一个@H_502_4@e的行相匹配@H_502_4@

grep ‘@H_502_4@l..e’@H_502_4@ test

awk ‘@H_502_4@/l..e/’@H_502_4@ test

cat test(@H_502_4@查看文件@H_502_4@)@H_502_4@

leeet

laat

lae

2、@H_502_4@^代表行的开始。@H_502_4@ ^love 如@H_502_4@:@H_502_4@与所有@H_502_4@love开头的行匹配@H_502_4@

grep ^le test@H_502_4@

3、@H_502_4@$代表行的结束。@H_502_4@love$ 如@H_502_4@:@H_502_4@与所有@H_502_4@love结尾的行匹配@H_502_4@

那么@H_502_4@‘^$’ 就表示空行@H_502_4@

grep at$test

4、@H_502_4@[…@H_502_4@]匹配括号中的字符之一@H_502_4@@H_502_4@

[abc]@H_502_4@匹配单个@H_502_4@字符@H_502_4@a或@H_502_4@b或@H_502_4@c

[123]@H_502_4@匹配单个@H_502_4@字符@H_502_4@1或@H_502_4@2或@H_502_4@3

[a-z]@H_502_4@匹配小写@H_502_4@字母@H_502_4@a-z之一@H_502_4@

[a-zA-Z]@H_502_4@匹配任意英文字之一@H_502_4@@H_502_4@

[0-9a-zA-Z]匹配任意英文字母或数字之一@H_502_4@@H_502_4@

注意:上面标红色的单个和之一,不管@H_502_4@[]里面多复杂,它的结果都是一个@H_502_4@字符!@H_502_4@

grep ‘@H_502_4@l[ae]e’@H_502_4@ test

awk‘@H_502_4@/l[ae]e/’@H_502_4@ test

可以用@H_502_4@^标记做@H_502_4@[]内的前缀@H_502_4@,表示除@H_502_4@@H_502_4@[]@H_502_4@内的字符之外@H_502_4@的字符。比如@H_502_4@ 搜索@H_502_4@oo前没有@H_502_4@g的字符串的行@H_502_4@. 应用@H_502_4@ '[^g]oo' 搜索字符串,@H_502_4@^符号如果出现在@H_502_4@@H_502_4@[]@H_502_4@的起始位置表示否定@H_502_4@,但是在@H_502_4@@H_502_4@[]@H_502_4@的其他位置是普通字符@H_502_4@。@H_502_4@[^9@H_502_4@b^c] 匹配@H_502_4@b或@H_502_4@^或@H_502_4@c不是@H_502_4@@H_502_4@a@H_502_4@的任意单个字符@H_502_4@

5@H_502_4@、* 用于修饰前导字符@H_502_4@,表示前导字符@H_502_4@出现0次@H_502_4@或任意多次@H_502_4@@H_502_4@

如:@H_502_4@'a*@H_502_4@grep'匹配所有@H_502_4@0@H_502_4@个或多个@H_502_4@a@H_502_4@后紧跟@H_502_4@grep的行。“@H_502_4@@H_502_4@.*@H_502_4@”表示任意字符串@H_502_4@

@H_502_4@

6@H_502_4@\?@H_502_4@用于修饰前导字符@H_502_4@,表示前导字符@H_502_4@出现0或1次@H_502_4@@H_502_4@

a\? @H_502_4@匹配0或1个a@H_502_4@

@H_502_4@

7@H_502_4@\+@H_502_4@用于修饰前导字符@H_502_4@,表示前导字符@H_502_4@出现1或多次@H_502_4@@H_502_4@

a\+ @H_502_4@匹配1或多个a@H_502_4@

@H_502_4@

8@H_502_4@\{n,m\}@H_502_4@@H_502_4@用于修饰前导字符@H_502_4@,表示前导字符出现n@H_502_4@至m次@H_502_4@(n和m都是整数,且n<m)@H_502_4@

a\{3,5\} @H_502_4@匹配3至5个连续的a@H_502_4@

@H_502_4@

\{n,m\}@H_502_4@还有其他几种形式:@H_502_4@

\{n\}@H_502_4@连续的n@H_502_4@个@H_502_4@前导字符@H_502_4@

\{n,\}@H_502_4@连续的至少n个@H_502_4@前导字符@H_502_4@

9@H_502_4@、\@H_502_4@用于转义紧跟其后的单个@H_502_4@特殊字符,使该特殊字符成为普通字符@H_502_4@

@H_502_4@

如:^@H_502_4@\@H_502_4@.@H_502_4@[0-9][0-9] @H_502_4@对@H_502_4@以一个@H_502_4@句点@H_502_4@和两个数字开始@H_502_4@

@H_502_4@

例如:@H_502_4@

a* @H_502_4@匹配连续的任意(也包括0)个a@H_502_4@

a\? @H_502_4@匹配0或1个a@H_502_4@

a\+ @H_502_4@匹配1或多个a@H_502_4@

a\{3,5\} @H_502_4@匹配3至5个连续的a@H_502_4@

\.* @H_502_4@匹配0或多个连续的. @H_502_4@@H_502_4@\.@H_502_4@表示普通字符句点@H_502_4@

@H_502_4@

sed @H_502_4@‘s/^ *[0-9]*//@H_502_4@’ test1@H_502_4@

history > test1@H_502_4@(先生成test1文件)@H_502_4@

10@H_502_4@、@H_502_4@|表示或@H_502_4@@H_502_4@ @H_502_4@如:@H_502_4@a|b|c 匹配@H_502_4@a或@H_502_4@b或@H_502_4@c。如:@H_502_4@grep|sed匹配@H_502_4@grep或@H_502_4@sed

@H_502_4@如:egrep @H_502_4@grep|sed@H_502_4@ test@H_502_4@

11、@H_502_4@(),将部分内容合成一个单位组,比如@H_502_4@搜索@H_502_4@ glad @H_502_4@或@H_502_4@ good@H_502_4@可以如下@H_502_4@ 'g(la|oo)d'@H_502_4@

@H_502_4@如:@H_502_4@egrep ‘g(la|oo)d’ test@H_502_4@

综合举例1:@H_502_4@

1 Christian Scott lives here and will put ona Christmas party.@H_502_4@

2 There are around 30 to 35 people invited. @H_502_4@

3 They are: @H_502_4@

4 Tom@H_502_4@

5 Dan@H_502_4@

6Rhonda Savage@H_502_4@

7 Nicky and Kimerly.@H_502_4@

8 Steve,Suzanne,Ginger and Larry. @H_502_4@

^[A-Z]..$@H_502_4@

搜索行以A至Z的一个字母开头,然后跟两个任意字母,然后跟一个换行符的行。将找到第5行。@H_502_4@

@H_502_4@

^[A-Z][a-z]*3[0-5]@H_502_4@

搜索以一个大写字母开头,后跟0个或多个小写字母,再跟数字3,再跟0@H_502_4@―5@H_502_4@之间的一个数字。无法找到匹配行(改成^[A-Z][a-z]*@H_502_4@.*@H_502_4@3[0-5]@H_502_4@可找到第2行)@H_502_4@

@H_502_4@

^@H_502_4@ *@H_502_4@[A-Z][a-z][a-z]$@H_502_4@

搜索以0个或多个空格开头,跟一个大写字母,两个小写字母和一个换车符。将找到第4行的TOM(整行匹配)和第5行。注意,@H_502_4@*@H_502_4@前面有一个空格@H_502_4@。@H_502_4@

@H_502_4@

@H_502_4@

综合举例2:@H_502_4@

# ls -l /bin | grep'^...s'@H_502_4@

上面的命令是用来查找suid文件的;@H_502_4@

# ls -lR /usr |grep '^...s..s'@H_502_4@

上面的命令是用来查找suid和guid的。@H_502_4@

@H_502_4@

二、@H_502_4@grep命令的用法@H_502_4@

grep (@H_502_4@global search regularexpression(RE) and print out the line,全面搜索正则表达式并把行打印出来@H_502_4@)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来@H_502_4@.

@H_502_4@

参数:@H_502_4@

1. -A NUM@H_502_4@,@H_502_4@--after-context=NUM @H_502_4@除了列出符合行之外,并且列出后@H_502_4@NUM@H_502_4@行。@H_502_4@

如@H_502_4@: $ grep �A 1 panda file (@H_502_4@从@H_502_4@file@H_502_4@中搜寻有@H_502_4@panda@H_502_4@样式的行,并显示该行的后@H_502_4@1@H_502_4@行@H_502_4@)@H_502_4@

@H_502_4@

2. -B NUM@H_502_4@,@H_502_4@--before-context=NUM @H_502_4@与@H_502_4@ -A NUM @H_502_4@相对,但这此参数是显示除符合行之外并显示在它之前的@H_502_4@NUM@H_502_4@行。如@H_502_4@: (@H_502_4@从@H_502_4@file@H_502_4@中搜寻有@H_502_4@panda@H_502_4@样式的行,并显示该行的前@H_502_4@1@H_502_4@行@H_502_4@)@H_502_4@

$ grep -B 1 panda file@H_502_4@

@H_502_4@

3@H_502_4@、@H_502_4@ -C [NUM],-NUM,--context[=NUM] @H_502_4@列出符合行之外并列出上下各@H_502_4@NUM@H_502_4@行,默认值是@H_502_4@2@H_502_4@。@H_502_4@

@H_502_4@

如@H_502_4@: (@H_502_4@列出@H_502_4@file@H_502_4@中除包含@H_502_4@panda@H_502_4@样式的行外并列出其上下@H_502_4@2@H_502_4@行@H_502_4@)(@H_502_4@若要改变默认值,直接改变@H_502_4@NUM@H_502_4@即可@H_502_4@)@H_502_4@

$ grep -C[NUM] panda file@H_502_4@

@H_502_4@

4@H_502_4@、@H_502_4@ -c,@H_502_4@ --count @H_502_4@不显示符合样式行,只显示符合的总行数。若再加上@H_502_4@-v,--invert-match@H_502_4@,参数显示不符合的总行数@H_502_4@

5@H_502_4@、@H_502_4@-i,@H_502_4@--ignore-case 忽略大小写差别@H_502_4@

@H_502_4@

6、@H_502_4@-n,@H_502_4@--line-number 在匹配的行前面打印行号@H_502_4@

7、@H_502_4@-v,@H_502_4@--revert-match 反检索,只显示不匹配的行@H_502_4@

8、精确匹配:@H_502_4@

例如在抽取字符串“ 48”,返回结果包含诸如484和483等包含“48”的其他字符串,实际上应精确抽取只包含48的各行。@H_502_4@

@H_502_4@

使用grep抽取精确匹配的一种有效方式是在抽取字符串前加@H_502_4@\@H_502_4@<,@H_502_4@在抽取字符串后加@H_502_4@\@H_502_4@>@H_502_4@。假定现在精确抽取48,@H_502_4@

方法如下:@H_502_4@

#grep '@H_502_4@\@H_502_4@<48\>' filename@H_502_4@

@H_502_4@

9@H_502_4@、-s 不显示不存在或无匹配文本的错误信息@H_502_4@

如:执行命令grep "root" /etc/password,因为password文件不存在,所以在屏幕上输出错误信息,若使用grep命令-s@H_502_4@开关,可屏蔽错误信息@H_502_4@@H_502_4@

@H_502_4@

要用好@H_502_4@grep这个工具,其实就是要写好正则表达式,所以这里不对@H_502_4@grep的所有功能进行实例讲解,只列几个例子,讲解一个正则表达式的写法。@H_502_4@

$ ls -l | grep '^d'
通过管道过滤@H_502_4@ls-l输出内容,只显示以@H_502_4@d开头的行。@H_502_4@

$ grep 'test'd*
显示所有以@H_502_4@d开头的文件中包含@H_502_4@test的行。@H_502_4@

$ grep 'test'aa bb cc
显示在@H_502_4@aa,@H_502_4@bb,@H_502_4@cc文件中匹配@H_502_4@test的行。@H_502_4@

$ grep '[a-z]\{5,\}'aa
显示所有包含每个字符串至少有@H_502_4@5个连续小写字符的字符串的行。@H_502_4@

$grep ‘t[a|e]st’filename

显示包含@H_502_4@test或@H_502_4@tast的所有行。@H_502_4@

$grep '\.$'filename

显示以@H_502_4@.为结尾的所有行。@H_502_4@

三、@H_502_4@sed命令的用法@H_502_4@

sed是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为@H_502_4@“模式空间@H_502_4@”(@H_502_4@pattern space),接着用@H_502_4@sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。@H_502_4@

sed@H_502_4@的基本命令@H_502_4@:@H_502_4@

1.@H_502_4@替换@H_502_4@: s命令@H_502_4@
1.1 基本用法@H_502_4@

如:@H_502_4@ sed 's/day/night/' <old >new
该例子将文件@H_502_4@ old 中的每一行第一次出现的@H_502_4@ day 替换成@H_502_4@ night,将结果输出文件@H_502_4@ new

s " 替换@H_502_4@ " 命令@H_502_4@
/../../ 分割符@H_502_4@ (Delimiter)
day 搜索字符串@H_502_4@
night 替换字符串@H_502_4@
其实@H_502_4@,分割符@H_502_4@ "/" 可以用别的符号代替@H_502_4@,比如@H_502_4@ ",","|" 等@H_502_4@ .
如:@H_502_4@sed's/\/usr\/local\/bin/\/common\/bin/'<old >new
等价于@H_502_4@ sed's_/usr/local/bin_/common/bin_' <old >new
显然@H_502_4@,此时用@H_502_4@ "_" 作分割符比@H_502_4@ "/" 好得多@H_502_4@

sed -i 's/anonymous=YES/anonymous=NO/' /etc/vsftpd/vsftpd.conf@H_502_4@

1.2 用@H_502_4@ & 表示匹配的字符串@H_502_4@

有时可能会想在匹配到的字符串周围或附近加上一些字符@H_502_4@ .
如:@H_502_4@ sed 's/abc/(abc)/' <old >new

该例子在找到的@H_502_4@ abc 前后加上括号@H_502_4@ .
该例子还可以写成@H_502_4@ sed 's/abc/(&)/' <old >new

下面是更复杂的例子@H_502_4@ :
sed 's/[a-z]*/(&)/' <old >new

sed 默认只替换搜索字符串的第一次出现@H_502_4@,利用@H_502_4@ /g 可以替换搜索字符串所有@H_502_4@

$ sed's/test/mytest/g' example-----在整行范围内把@H_502_4@test替换为@H_502_4@mytest。如果没有@H_502_4@g标记,则只有每行第一个匹配的@H_502_4@test被替换成@H_502_4@mytest。@H_502_4@

$ sed's/^192.168.0.1/&localhost/' example-----&符号表示替换字符串中被找到的部份。所有以@H_502_4@192.168.0.1开头的行都会被替换成它自已加@H_502_4@ localhost,变成@H_502_4@192.168.0.1localhost。@H_502_4@

$ sed's#10#100#g' example-----不论什么字符,紧跟着@H_502_4@s命令的都被认为是新的分隔符,所以,@H_502_4@“#”在这里是分隔符,代替了默认的@H_502_4@“/”分隔符。表示把所有@H_502_4@10替换成@H_502_4@100。@H_502_4@

如果需要对同一文件或行作多次修改,可以使用@H_502_4@ "-e" 选项@H_502_4@

502" height="24" src="http://img.jb51.cc/vcimg/static/loading.png" style="background:url("/e/u261/themes/default/images/word.gif") no-repeat center;border:1px solid #ddd;" alt="spacer.gif" src="http://mengwumian.blog.51cto.come/u261/themes/default/images/spacer.gif">

取得@H_502_4@eth0网卡@H_502_4@IP地址:@H_502_4@

spacer.gif

2删除行:@H_502_4@d命令@H_502_4@

从某文件删除包含@H_502_4@ "how" @H_502_4@的所有行@H_502_4@

spacer.gif

将@H_502_4@/etc/passwd内容显示并找印行号,同时将@H_502_4@2~5删除@H_502_4@

spacer.gif

附:@H_502_4@nl@H_502_4@命令在@H_502_4@linux系统中用来计算文件中行号@H_502_4@。@H_502_4@nl @H_502_4@可以将输出文件内容自动加上行号@H_502_4@

如果只要删除第@H_502_4@2行,可以使用@H_502_4@nl /etc/passwd | sed '2d' 来达成,至于若是要删除第@H_502_4@ 3 到最后一行,则是@H_502_4@nl /etc/passwd | sed '3,$d'的啦。@H_502_4@

3增加行:@H_502_4@a命令(在指定的行后新增)或@H_502_4@i命令(在指定的行前新增)@H_502_4@

a的后面可以接字符串,而这些字符串会在新的一行出现@H_502_4@

在@H_502_4@/etc/passwd的第二行后增加“@H_502_4@XXXXX”字样的新行@H_502_4@

spacer.gif

在@H_502_4@/etc/passwd的第二行前增加“@H_502_4@XXXXX”字样的新行@H_502_4@

spacer.gif

如果要同时新增多行,则每行之间要用反斜杠@H_502_4@\来进行新行的添加@H_502_4@

spacer.gif

sed -i '/\[global\]/a test' /etc/samba/smb.conf

sed -i '57a test' /etc/samba/smb.conf

4、取代行:@H_502_4@c命令@H_502_4@

c的后面可以接字符串,这些字符串可以取代@H_502_4@n1,n2之间的行@H_502_4@

spacer.gif

5、打印:@H_502_4@p命令@H_502_4@

sed '/north/p' datafile 默认输出所有行,找到@H_502_4@north的行重复打印@H_502_4@

sed �n '/north/p' datafile 禁止默认输出,只打印找到@H_502_4@north的行@H_502_4@

nl /etc/passwd | sed -n '5,7p' 仅列出@H_502_4@/etc/passwd文件中的第@H_502_4@5~@H_502_4@7内容@H_502_4@

注:@H_502_4@sed 的@H_502_4@-i选项可以直接修改文件中的内容@H_502_4@

spacer.gif

四、@H_502_4@awk命令:@H_502_4@

awk也是一个数据处理工具!相较于@H_502_4@ sed 常常作用于一整个行的处理,@H_502_4@ awk 则比较倾向于一行当中分成数个字段来处理。@H_502_4@

.@H_502_4@awk语言的最基本功能是在文件或字符串中基于指定规则来分解抽取信息,也可以基于指定的规则来输出数据。@H_502_4@

1.命令格式@H_502_4@

awk [-F field-separator] 'commands'input-files

其中,@H_502_4@[-F域分隔符@H_502_4@]是可选的,因为@H_502_4@awk使用空格或@H_502_4@tab键作为缺省的域分隔符,因此如果要浏览域间有空格的文本,不必指定这个选项,如果要浏览诸如@H_502_4@passwd文件,此文件各域以冒号作为分隔符,则必须指明@H_502_4@-F选项,如:@H_502_4@awk -F: 'commands' input-file。@H_502_4@

awk@H_502_4@的模式和@H_502_4@动作@H_502_4@

任何@H_502_4@awk语句都由模式和动作组成(@H_502_4@awk_pattern { actions }@H_502_4@)。@H_502_4@
在一个@H_502_4@awk脚本中可能有许多语句。@H_502_4@

模式@H_502_4@部分决定动作语句何时触发及触发事件。处理即对数据进行的操作。如果省略模式部分,动作将时刻保持执行状态。即@H_502_4@省略时不对输入记录进行匹配比较就执行相应的actions。@H_502_4@

模式@H_502_4@可以是任何条件语句或正则表达式等。@H_502_4@awk_pattern@H_502_4@可以是以下几种类型:@H_502_4@

@H_502_4@

1) @H_502_4@正则表达式用作awk_pattern: /regexp/@H_502_4@

例如:awk '/ ^[a-z]/' input_file@H_502_4@

2) @H_502_4@布尔表达式用作awk_pattern,表达式成立时,触发相应的actions执行。@H_502_4@

①@H_502_4@ 表达式中可以使用变量(如字段变量$1,$2等)和/regexp/@H_502_4@

② 布尔表达式中的操作符:@H_502_4@

@H_502_4@

关系操作符: < > <= >= == !=
匹配操作符: value ~ /regexp/ 如果value匹配/regexp/,则返回真@H_502_4@
@H_502_4@value !~ /regexp/ @H_502_4@如果value不匹配/regexp/,则返回真@H_502_4@
@H_502_4@例如: awk '$2 > 10 {print"ok"}' input_file
awk '$3 ~ /^d/ {print"ok"}' input_file@H_502_4@

③ &&(与)和 ||(或) 可以连接两个/regexp/或者布尔表达式,构成混合表达式。!(非) 可以用于布尔表达式或者/regexp/之前。@H_502_4@

@H_502_4@

例如: awk '($1 < 10 ) && ($2> 10) {print "ok"}' input_file
awk '/^d/ || /x$/ {print"ok"}' input_file@H_502_4@

模式包括两个特殊字段@H_502_4@ BEGIN和@H_502_4@END。使用@H_502_4@BEGIN语句设置计数和打印头。@H_502_4@BEGIN语句使用在任何文本浏览动作之前,之后文本浏览动作依据输入文本开始执行。@H_502_4@END语句用来在@H_502_4@awk完成文本浏览动作后打印输出文本总数和结尾状态标志。@H_502_4@

实际动作在大括号@H_502_4@{@H_502_4@ }@H_502_4@内指明。动作大多数用来打印@H_502_4@,但是还有些更长的代码诸如i f和循环语句及循环退出结构。如果不指明采取动作,awk将打印出所有浏览出来的记录。@H_502_4@

@H_502_4@

awk@H_502_4@执行时,其浏览域标记为$1,$2...$n。这种方法称为域标识。使用这些域标识将更容易对域进行进一步处理。@H_502_4@

@H_502_4@

使用$1,$3表示参照第1和第3域,注意这里用逗号做域分隔。如果希望打印一个有5个域@H_502_4@

的记录的所有域,不必指明$1,$2,$3,$4,$5,可使用$@H_502_4@0@H_502_4@,意即所有域。@H_502_4@

为打印一个域或所有域,使用print命令。这是一个awk动作@H_502_4@@H_502_4@

@H_502_4@

awk@H_502_4@的运行过程:@H_502_4@

@H_502_4@@H_502_4@如果BEGIN区块存在,awk执行它指定的actions。@H_502_4@

@H_502_4@@H_502_4@awk@H_502_4@从输入文件中读取一行,称为一条输入记录。(如果输入文件省略,将从标准输入读取)@H_502_4@

@H_502_4@@H_502_4@awk@H_502_4@将读入的记录分割成字段,将第1个字段放入变量$1中,第2个字段放入$2,以此类推。$0表示整条记录。@H_502_4@

@H_502_4@@H_502_4@@H_502_4@把当前输入记录依次与每一个awk_cmd中awk_pattern比较,看是否匹配,如果相匹配,就执行对应的actions。如果不匹配,就跳过对应的actions,直到比较完所有的awk_cmd。@H_502_4@

@H_502_4@@H_502_4@@H_502_4@当一条输入记录比较了所有的awk_cmd后,awk读取输入的下一行,继续重复步骤@H_502_4@③@H_502_4@和@H_502_4@④@H_502_4@,这个过程一直持续,直到awk读取到文件尾。@H_502_4@

@H_502_4@@H_502_4@@H_502_4@当awk读完所有的输入行后,如果存在END,就执行相应的actions。@H_502_4@

@H_502_4@

入门实例:@H_502_4@

例1:显示/etc/passwd文件中的用户名登录shell @H_502_4@

502" height="16" src="http://img.jb51.cc/vcimg/static/loading.png" style="background:url("/e/u261/themes/default/images/word.gif") no-repeat center;border:1px solid #ddd;" alt="spacer.gif" src="http://mengwumian.blog.51cto.come/u261/themes/default/images/spacer.gif">

@H_502_4@

如果只是显示/etc/passwd的账户和账户对应的shell,而账户与shell之间以tab键分割@H_502_4@

spacer.gif

@H_502_4@

如果只是显示/etc/passwd文件中的用户名登录shell,而账户与shell之间以逗号分割@H_502_4@

spacer.gif

@H_502_4@

注:awk的总是输出到标准输出,如果想让awk输出文件,可以使用重定向。@H_502_4@

@H_502_4@

例2:显示/etc/passwd文件中的UID大于500的所有用户用户名登录shell@H_502_4@

spacer.gif

@H_502_4@

例3:如果只是显示/etc/passwd文件中的UID大于500的用户名登录shell@H_502_4@,@H_502_4@而账户与shell之间以逗号分割@H_502_4@,@H_502_4@而且在所有行添加列名name,shell,在最后一行添加"blue,/bin/nosh"。@H_502_4@

spacer.gif

注:@H_502_4@

1.awk @H_502_4@后面接两个单引号并加上大括号@H_502_4@ {} @H_502_4@来设定想要对数据进行的处理动作@H_502_4@

2.awk@H_502_4@工作流程是这样的:先执行@H_502_4@BEGING@H_502_4@,然后读取文件,读入有@H_502_4@\@H_502_4@n@H_502_4@换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,@H_502_4@$0@H_502_4@则表示所有域@H_502_4@,$1@H_502_4@表示第一个域@H_502_4@,$n@H_502_4@表示第@H_502_4@n@H_502_4@个域@H_502_4@,@H_502_4@随后开始执行模式所对应的动作。接着开始读入第二条记录・・・・・・直到所有的记录都读完,最后执行@H_502_4@END@H_502_4@操作。@H_502_4@

思考题:如何打印所有记录(以@H_502_4@/etc/passwd@H_502_4@中的内容为例)@H_502_4@

spacer.gif

@H_502_4@

例@H_502_4@4@H_502_4@搜索@H_502_4@/etc/passwd@H_502_4@有@H_502_4@root@H_502_4@关键字的所有行@H_502_4@

spacer.gif

@H_502_4@@H_502_4@

这种是@H_502_4@pattern@H_502_4@(模式)的使用示例,匹配了@H_502_4@pattern(@H_502_4@这里是@H_502_4@root)@H_502_4@的行才会执行@H_502_4@action(@H_502_4@没有指定@H_502_4@action@H_502_4@,默认输出每行的内容@H_502_4@)@H_502_4@。@H_502_4@

搜索支持正则表达式,例如找@H_502_4@root@H_502_4@开头的@H_502_4@:@H_502_4@

spacer.gif

@H_502_4@

搜索@H_502_4@/etc/passwd@H_502_4@有@H_502_4@root@H_502_4@关键字的所有行,并显示对应的@H_502_4@shell@H_502_4@

spacer.gif

@H_502_4@

这里指定了@H_502_4@action@H_502_4@是@H_502_4@{@H_502_4@print $7}@H_502_4@

猜你在找的正则表达式相关文章