sed是一个很好的文件处理工具,自己是一个管道命令,主要是以行为单位进行处理,能够将数据行进行替换、删除、新增、选取等特定工做,下面先了解一下sed的用法
sed命令行格式为:
sed [-nefri] ‘command’ 输入文本 正则表达式
经常使用选项:
-n∶使用安静(silent)模式。在通常 sed 的用法中,全部来自 STDIN的资料通常都会被列出到萤幕上。但若是加上 -n 参数后,则只有通过sed 特殊处理的那一行(或者动做)才会被列出来。
-e∶直接在指令列模式上进行 sed 的动做编辑;
-f∶直接将 sed 的动做写在一个档案内, -f filename 则能够执行 filename 内的sed 动做;
-r∶sed 的动做支援的是延伸型正规表示法的语法。(预设是基础正规表示法语法)
-i∶直接修改读取的档案内容,而不是由萤幕输出。 ruby
经常使用命令:
a ∶新增, a 的后面能够接字串,而这些字串会在新的一行出现(目前的下一行)~
c ∶取代, c 的后面能够接字串,这些字串能够取代 n1,n2 之间的行!
d ∶删除,由于是删除啊,因此 d 后面一般不接任何咚咚;
i ∶插入, i 的后面能够接字串,而这些字串会在新的一行出现(目前的上一行);
p ∶列印,亦即将某个选择的资料印出。一般 p 会与参数 sed -n 一块儿运做~
s ∶取代,能够直接进行取代的工做哩!一般这个 s 的动做能够搭配正规表示法!例如 1,20s/old/new/g 就是啦!工具
举例:(假设咱们有一文件名为ab)
删除某行
[root@localhost ruby] # sed '1d' ab #删除第一行
[root@localhost ruby] # sed '$d' ab #删除最后一行
[root@localhost ruby] # sed '1,2d' ab #删除第一行到第二行
[root@localhost ruby] # sed '2,$d' ab #删除第二行到最后一行spa
显示某行
. [root@localhost ruby] # sed -n '1p' ab #显示第一行
[root@localhost ruby] # sed -n '$p' ab #显示最后一行
[root@localhost ruby] # sed -n '1,2p' ab #显示第一行到第二行
[root@localhost ruby] # sed -n '2,$p' ab #显示第二行到最后一行命令行
使用模式进行查询
[root@localhost ruby] # sed -n '/ruby/p' ab #查询包括关键字ruby所在全部行
[root@localhost ruby] # sed -n '/\$/p' ab #查询包括关键字$所在全部行,使用反斜线\屏蔽特殊含义blog
增长一行或多行字符串
[root@localhost ruby]# cat ab
Hello!
ruby is me,welcome to my blog.
end
[root@localhost ruby] # sed '1a drink tea' ab #第一行后增长字符串"drink tea"
Hello!
drink tea
ruby is me,welcome to my blog.
end
[root@localhost ruby] # sed '1,3a drink tea' ab #第一行到第三行后增长字符串"drink tea"
Hello!
drink tea
ruby is me,welcome to my blog.
drink tea
end
drink tea
[root@localhost ruby] # sed '1a drink tea\nor coffee' ab #第一行后增长多行,使用换行符\n
Hello!
drink tea
or coffee
ruby is me,welcome to my blog.
end字符串
代替一行或多行
[root@localhost ruby] # sed '1c Hi' ab #第一行代替为Hi
Hi
ruby is me,welcome to my blog.
end
[root@localhost ruby] # sed '1,2c Hi' ab #第一行到第二行代替为Hi
Hi
endclass
替换一行中的某部分
格式:sed 's/要替换的字符串/新的字符串/g' (要替换的字符串能够用正则表达式)
[root@localhost ruby] # sed -n '/ruby/p' ab | sed 's/ruby/bird/g' #替换ruby为bird
[root@localhost ruby] # sed -n '/ruby/p' ab | sed 's/ruby//g' #删除rubytest
插入
[root@localhost ruby] # sed -i '$a bye' ab #在文件ab中最后一行直接输入"bye"
[root@localhost ruby]# cat ab
Hello!
ruby is me,welcome to my blog.
end
bye基础
例如:
[asp@BJ-CP-7F-106-36 result]$ cat 11371_mobile_20110425.csv
20110425,北京,北京,13661189983
20110425,北京,北京,15810705979
WAPSJBBI_101>
WAPSJBBI_101>spooloff;
[asp@BJ-CP-7F-106-36 result]$ sed -i '/WAPSJBBI_101>/d'11371_mobile_20110425.csv
[asp@BJ-CP-7F-106-36 result]$ cat 11371_mobile_20110425.csv
20110425,北京,北京,13661189983
20110425,北京,北京,15810705979
从结果上看怎么就2行都删了呢?
答案是这样的:
sed 后面那个/d是删除的做用,写成sed '/WAPSJBBI_101>/d' 11371_mobile_20110425.csv其实就是在文件11371_mobile_20110425.csv里找到跟 “WAPSJBBI_101>”匹配的行,而后删掉。由于原文中含有“WAPSJBBI_101>”的行是2个,所以就2个一口气都删除了。
删除:d命令
$ sed '2d' example-----删除example文件的第二行。
$ sed '2,$d' example-----删除example文件的第二行到末尾全部行。
$ sed '$d' example-----删除example文件的最后一行。
$ sed '/test/'d example-----删除example文件全部包含test的行。
在看看之前我常写的sed 's/|/,/g' aaa.txt>bbb.txt 这个的意思就是把aaa.txt文件中全部字符串|都换成,这是怎么表示的呢?S表明字符串,g表示行内全面替换。
替换:s命令
$ sed 's/test/mytest/g' example
-----在整行范围内把test替换为mytest。若是没有g标记,则只有每行第一个匹配的test被替换成mytest。
$ sed -n 's/^test/mytest/p' example
-----(-n)选项和p标志一块儿使用表示只打印那些发生替换的行。也就是说,若是某一行开头的test被替换成mytest,就打印它。
$ sed 's/^192.168.0.1/&localhost/' example
-----&符号表示替换换字符串中被找到的部份。全部以192.168.0.1开头的行都会被替换成它自已加 localhost,变成192.168.0.1localhost。
$ sed -n 's/loveable/\1rs/p' example
-----love被标记为1,全部loveable会被替换成lovers,并且替换的行会被打印出来。
$ sed 's#10#100#g' example
-----不论什么字符,紧跟着s命令的都被认为是新的分隔符,因此,“#”在这里是分隔符,代替了默认的“/”分隔符。表示把全部10替换成100。