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是流编辑器, 流有去无回, 想象一下管道, 你没有能力再回到一个流的当前位置之前. 而且它也不做缓冲.
阅读(1207) | 评论(0) | 转发(0) |