sed 用法

linux sed 用法

2. 定址 
4. 选项 
6. 实例 
sed -i 's/被替换的内容/要替换成的内容/' file

sed 's/被替换的内容/要替换成的内容/g' file > file.out
这里注意:
sed 's/被替换的内容/要替换成的内容/g' file > file




a\ 
分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾。
用新的文本改变本行的文本。
从模板块(Pattern space)位置删除行。
删除模板块的第一行。
在当前行上面插入文本。
拷贝模板块的内容到内存中的缓冲区。
追加模板块的内容到内存中的缓冲区
获得内存缓冲区的内容,并替代当前模板块中的文本。
获得内存缓冲区的内容,并追加到当前模板块文本的后面。
列表不能打印字符的清单。
读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。
追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码。
打印模板块的行。
打印模板块的第一行。
退出Sed。
从file中读行。
if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。
错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。
写并追加模板块到file末尾。
写并追加模板块的第一行到file末尾。
表示后面的命令对所有没有被选定的行发生作用。
用string替换正则表达式re。
打印当前行号码。
把注释扩展到下一个换行符以前。


打印帮助,并显示bug列表的地址。
取消默认输出。
引导sed脚本文件名。
打印版本和版权信息。


锚定行的开始 如:/^sed/匹配所有以sed开头的行。
锚定行的结束 如:/sed$/匹配所有以sed结尾的行。
匹配一个非换行符的字符 如:/s.d/匹配s后接一个任意字符,然后是d。
匹配零或多个字符 如:/*sed/匹配所有模板是一个或多个空格后紧跟sed的行。
匹配一个指定范围内的字符,如/[Ss]ed/匹配sed和Sed。
匹配一个不在指定范围内的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一个字母开头,紧跟ed的行。
保存匹配的字符,如s/\(love\)able/\1rs,loveable被替换成lovers。
保存搜索字符用来替换其他字符,如s/love/**&**/,love这成**love**。
锚定单词的开始,如:/\
锚定单词的结束,如/love\>/匹配包含以love结尾的单词的行。
重复字符x,m次,如:/0\{5\}/匹配包含5个o的行。
重复字符x,至少m次,如:/o\{5,\}/匹配至少有5个o的行。
重复字符x,至少m次,不多于n次,如:/o\{5,10\}/匹配5--10个o的行。
删除:d命令 
$ sed 's/test/mytest/g' example-----在整行范围内把test替换为mytest。如果没有g标记,则只有每行第一个匹配的test被替换成mytest。
$ sed -n '/test/,/check/p' example-----所有在模板test和check所确定的范围内的行都被打印。
$ sed -e '1,5d' -e 's/test/check/' example-----(-e)选项允许在同一行里执行多条命令。如例子所示,第一条命令删除1至5行,第二条命令用check替换test。命令的执 行顺序对结果有影响。如果两个命令都是替换命令,那么第一个替换命令将影响第二个替换命令的结果。
$ sed '/test/r file' example-----file里的内容被读进来,显示在与test匹配的行后面,如果匹配多行,则file的内容将显示在所有匹配行的下面。
$ sed -n '/test/w file' example-----在example中所有包含test的行都被写入file里。

$ sed '/^test/a\\--->this is a example' example<-----'this is a example'被追加到以test开头的行后面,sed要求命令a后面有一个反斜杠。
$ sed '/test/i\\
$ sed '/test/{ n; s/aa/bb/; }' example-----如果test被匹配,则移动到匹配行的下一行,替换这一行的aa,变为bb,并打印该行,然后继续。
$ sed '1,10y/abcde/ABCDE/' example-----把1--10行内所有abcde转变为大写,注意,正则表达式元字符不能使用这个命令。
$ sed '10q' example-----打印完第10行后,退出sed。
$ sed -e '/test/h' -e '$G example-----在sed处理文件的时候,每一行都被保存在一个叫模式空间的临时缓冲区中,除非行被删除或者输出被取消,否则所有被处理的行都将 打印在屏幕上。接着模式空间被清空,并存入新的一行等待处理。在这个例子里,匹配test的行被找到后,将存入模式空间,h命令将其复制并存入一个称为保 持缓存区的特殊缓冲区内。第二条语句的意思是,当到达最后一行后,G命令取出保持缓冲区的行,然后把它放回模式空间中,且追加到现在已经存在于模式空间中 的行的末尾。在这个例子中就是追加到最后一行。简单来说,任何包含test的行都被复制并追加到该文件的末尾。
$ sed -e '/test/h' -e '/check/x' example -----互换模式空间和保持缓冲区的内容。也就是把包含test与check的行互换。
Sed脚本是一个sed的命令清单,启动Sed时以-f选项引导脚本文件名。Sed对于脚本中输入的命令非常挑剔,在命令的末尾不能有任何空白或文本,如果在一行中有多个命令,要用分号分隔。以#开头的行为注释行,且不能跨行。

cat filename | sed –n ‘/1024/p’sed命令详解!!(要学习shell的 朋友要好好看看)
sed可删除(delete)、改变(change)、添加(append)、插入(insert)、合、交换文件中的资料行,或读入其它档的资料到文 >件中,也可替换(substuite)它们其中的字串、或转换(tranfer)其中的字母等等。例如将文件中的连续空白行删成一行、 "local"字串替换成"remote"、"t"字母转换成"T"、将第10行资料与第11资料合等.
小结,记住:
(2)sed处理的不是原文件而是原文件的拷贝
sed 编辑指令的格式如下 :
其中 , 位址参数 address1 、address2 为行数或 regular expression 字串 , 表示所执行编辑的资料行; 函数参数 function[argument] 为 sed 的内定函数 , 表示执行的编辑动作。
下页表中介绍所有 sed 的函数参数(参照[chapter 4])的功能。
: label  建立 script file 内指令互相参考的位置。
{ }  集合有相同位址参数的指令。
=  印出资料行数( line number )。
b label  将执行的指令跳至由 : 建立的参考位置。
d  删除资料。
g  拷贝资料从 hold space。
h  拷贝资料从 pattern space 至 hold space 。
l  印出 l 资料中的 nonprinting character 用 ASCII 码。
n  读入下一笔资料。
p  印出资料。
q  跳出 sed 编辑。
s  替换字串。
w  写资料到它档内。
y  转换(transform)字元。
(1) sed -e '1d' inputfile (删除第一行)
sed -e 'xd' inputfile
当然也许还有更好的办法。
思考:删除第n行到第m行?也就是
删除第一行到最后一行
思考:删除含有字母xx的行
思考: 删除除含有字符串xx的所有行
sed -e '10,/word1/d' file
sed -e '/word1/,10/d' file
思考:删除含有指定正在表达式匹配的行。

Sed 可替换文件中的字串、资料行、甚至资料区。其中,表示替换字串的指令中的函数参数为s;表示替换资料行、或资料区>的指令中的函数参数为c。上述情况以下面三个例子说明。
(1) sed -e '1c\#!/bin/more' file (把第一行替换成#!/bin/more)
sed -e 'nc\just do it' file
思考: 换成两行(I can do it! Let's start)
(3) sed -e 's/word1/& word2/' file (将每一行的word1单词替换成s参数最多与两个位置参数相结合,函数参数s中有两个特殊的符号:
\n : 代表 pattern 中被第 n 个 \( 、\)(参照[附录 A]) 所括起来的字串。例如
sed -e  's/\(test\) \(my\) \(car\)/[\2 \3 \1]/' file   #结果: [my car test]
sed -e 's/w1/& w2/g' file
sed -e 's/w1/& w2/10' file
sed -e 's/w1/& w2/p' file
sed -e 's/w1/& w2/w w2file' file
这里的flag 为空, 这样就只是将第一个w1匹配的字符串替换成w1 w2而后面的不进行替换。
sed -e '/machine/s/phi/beta/g' file

把1到10内的w1字符串替换成w1 w2字符串。
把1到字符串else内的w1字符串替换成w1 w2字符串。

i
[address] i\ 插入内容 filename
说明:
[address1[ ,address2]] s/pattern/replacemen/[flag]
这里的函数参数是i,它只能有一个地址参数。
在第一行前加一行words

i 参数正好与a参数相反,它是插入到所给内容的前面.
a参数的使用格式如下:

unix
基本格式:
(2) sed -n '/then/ p' filename  #只打印含有then的行
(4) sed -n '1,3 p' filename     # 打印1-3行

例如:
把文件中的a字母替换成x, b替换成y, c替换成z。
把小写的abc转换成大写的ABC
基本格式:
删除除了含有1996的所有行。

基本格式:
函数参数 c 紧接着 "\" 字元用来表示此行结束 , 使用者所输入的资料必须从下一行输入。如果资料超过一行 , 则须在>每行的结尾加入"\"
表示把含有字符串zhengxh的行,该成hhhh。
基本格式:
表示输出文件,但如果一行含有字符串echo,则输出包含该字符串的下一行。
输出文中的偶数行
一次执行多个命令的方式有三种:
(2) sed -e 'cmd1' -e 'cmd2'  filename     (使用多个-e参数)

本文出自 “Mr_Z” 博客,请务必保留此出处http://zhangrong.blog.51cto.com/2196532/1031385

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值