1、正则表达式
regex 描述
/./ 包含至少一个字符串的行
/../ 包含至少两个字符串的行
/^#/ 匹配任何以‘#’开头的行
/#$/ 匹配任意以‘#’结尾的行
/[abc]/ 包含‘a’或‘b’或‘c’的行
/^[abc]/ 匹配任何以‘a’或‘b’或‘c’开始的行
|
|
[:alnum:] |
字母数字 [a-z A-Z 0-9] |
[:alpha:] |
字母 [a-z A-Z] |
[:blank:] |
空格或制表键 |
[:cntrl:] |
任何控制字符 |
[:digit:] |
数字 [0-9] |
[:graph:] |
任何可视字符(无空格) |
[:lower:] |
小写 [a-z] |
[:print:] |
非控制字符 |
[:punct:] |
标点字符 |
[:space:] |
空格 |
[:upper:] |
大写 [A-Z] |
[:xdigit:] |
十六进制数字 [0-9 a-f A-F] |
2、删除文件filename中所有符合regex正则表达式的行
sed -e '/regex/d' filename
3、地址范围匹配
sed -e '1d' filename -------->删除第一行
sed -e '1,100d' filename ------------>删除第1到100行
4、指定多个正则表达式
sed -e '/begin/,/end/p' filename ---------->打印从以'begin'开头的到以'end'结束的所有行,如果没有发现begin,则不进行打印,如果发现begin,则打印后续所有行,不管有没有发现end
5、替换命令
sed -e 's/foo/bar/' filename --->将filename中每行第一次出现的'foo'替换为'bar'
sed -e 's/foo/bar/g' filename --->将filename中所有'foo'替换为'bar'
sed -e '1,10s/foo/bar/g' filename -->将filename中第1行到第10行(包括这两行)出现的所有'foo'替换为'bar'
sed -e 's:foo:bar:g' filename --> 将filename中所有'foo'替换为'bar'
sed -e 's/<.*>//g' filename --> 将filename中以'<'开始,中间有任意个字符,并以'>'结束的最长匹配替换为空格
sed -e 's/<[^>]*>//g' filename -->将试图匹配最短的字符块
sed -e 's/.*/hlz: $/g' filename -->在每行前面插入'hlz: ',&作用是插入整个匹配的规则表达式
待续。。。
阅读(878) | 评论(0) | 转发(0) |