天天看点

shell编程入门步步高(九、sed和awk)

正则表达式

一个点(.)代表一个字符。

比如:.a. 代表3个字符,中间一个字符是a,两边各一个任意字符。

比如:... 代表3个任意字符。

若要匹配点(.)本身,则使用转义字符。

比如:my\... 代表my.后接两个字符。

行首匹配^

行尾匹配$

[...] 代表字符串中的一个字符。

比如:[abc] 代表a或b或c中的任意一个字符。

比如:[Mm]y 代表My或者my。

^出现在[]里,代表“非”

比如:[^a]代表不是a

*代表前面的字符有0个或者0个以上

比如:a*b代表ab或aab或aaab等。

\{...\}代表制定符合的个数。

比如:\{1,5\}代表前面的字符有1-5个。

Sed

sed基本语法:sed '样式' 文件

样式中,使用// 代表寻找,比如1,5代表第一到第五行,/aaa/,/bbb/ 表示作用范围从aaa的行到bbb的行。

例子:

sed '1,4d' file 指的是把第一到第四行删除。

sed '/aaa/d' file 指的是把还有aaa的那行删除。

sed '/[0-9]\{3\}/d' file 指的是把还有3个数字的行删除。

sed '/^$/d' file 指的是把空白行删除。

sed '/aaa/!d' file 指的是把不含有aaa行的删除。

sed '/aaa/p' file 指的是把含有aaa的行显示出来。

sed -n '/aaa/p' file 指的是把含有aaa的行显示出来,同时显示行号。

使用sed取代字符

sed 's/aaa/bbb/p' file 将bbb取代aaa,只取代一次。

sed 's/aaa/bbb/pg' file 将bbb取代aaa,全部取代。

sed 's/aaa//p' file 将aaa删除,只删除一次。

sed 's/^...//' file 将每行的前3个字符删除。

sed 's/...$//' file 将每行的后3个字符删除。

sed -n 's/\(a\)/\1b/p' file 找到第一个a然后替换成ab。

awk

awk '/aa/' file 显示含有aa的行。

awk '{print $1, $2}' file 显示第一第二字段。

awk '/aa/{print $1, $2}' file 将含有aa的行的第一和第二个字段显示出来。

awk -F: '/^root/{print $1, $2}' /etc/passwd 指定:为分隔符,打印第一和第二字段。

awk -F: 'BEGIN{OFS="+++"}'/^root/{print $1, $2} /etc/passwd 以:为分隔符,打印第一和第二段,而且彼此用+++分开。

本文转自 justiceplus 51CTO博客,原文链接:http://blog.51cto.com/johnwang/327154,如需转载请自行联系原作者