Chinaunix首页 | 论坛 | 博客
  • 博客访问: 158788
  • 博文数量: 25
  • 博客积分: 1222
  • 博客等级: 中尉
  • 技术积分: 322
  • 用 户 组: 普通用户
  • 注册时间: 2007-09-27 10:18
文章分类
文章存档

2011年(7)

2010年(9)

2009年(9)

我的朋友

分类: LINUX

2009-09-06 23:18:11

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: ',&作用是插入整个匹配的规则表达式
待续。。。
 
阅读(869) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~