Chinaunix首页 | 论坛 | 博客
  • 博客访问: 616763
  • 博文数量: 201
  • 博客积分: 3076
  • 博客等级: 中校
  • 技术积分: 2333
  • 用 户 组: 普通用户
  • 注册时间: 2009-08-02 19:44
文章分类

全部博文(201)

文章存档

2010年(118)

2009年(83)

我的朋友

分类: LINUX

2009-11-29 16:30:11



1. 将每行第一个字符变为大写:
    sed 's/[a-zA-Z]/\U&/' file
    awk -F '' -v OFS='' '{$1=toupper($1);print} file //''表示两个'号
2. 将每个单词的开头替换为大写:
    sed 's/\<[a-z]/\U&/g' file
    ps: 小写 \L
    sed "s/\w\+/\u&/g"
3. 替换 /etc/shadow 第5个字段
    sed 's/[a-zA-Z0-9]/\+:/string:/4' /etc/shadow
    sed 's/[a-zA-Z0-9]/*:/string:/5' /etc/shadow
4. 在不是#开头的行增加空格
   sed '/^#/!s/^/ /'             sed 's/^[^#]/ &/'

5. echo http/access.200907300000.gz |sed 's/\(.*\)0000\(.*\)/\11400\2/'
http/access.200907301400.gz

echo http/access.200907300000.gz |sed 's/0000/1400/'
    http/access.200907314000.gz
----------
sed '/pattern/{d;q;}' file.txt

原以为会退出, 其实d后面的命令都不会被执行了, sed 的内部工作机制是看到d命令后把pattern space的内容删除, 当然就不会有默认的print动作了, 然后开始处理下一条的记录, 后面的东西就给忽略了.

d; 具有一个隐含的短路作用. 相当于在d之后跟了一个 goto, 这样{}分组的命令集中后面的命令就没有机会被执行到了.

================
额外地, n和N命令读入下一条记录, 那么已n或N已经读取的下一条记录还会不会被再次处理?

答案是不会. sed是流编辑器, 流有去无回, 想象一下管道, 你没有能力再回到一个流的当前位置之前. 而且它也不做缓冲.
阅读(1191) | 评论(0) | 转发(0) |
0

上一篇:tcp/ip协议对应的编号

下一篇:svn

给主人留下些什么吧!~~