- 论坛徽章:
- 0
|
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: ',&作用是插入整个匹配的规则表达式
待续。。。
本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u1/49562/showart_2046821.html |
|