现在的位置: 首页 > 自动控制 > 工业·编程 > 正文

shell学习之-sed用法解析

2016-07-31 22:23 工业·编程 ⁄ 共 5239字 ⁄ 字号 暂无评论

1,sed介绍

    sed可删除(delete)、改变(change)、添加(append)、插入(insert)、合、交换文件中的资料行,或读入其它档的资料到文>件中,也可替换(substuite)它们其中的字串、或转换(tranfer)其中的字母等等。例如将文件中的连续空白行删成一行、"local"字串替换成"remote"、"t"字母转换成"T"、将第10行资料与第11资料合等.

    总合上述所言,当sed由标准输入读入一行资料并放入pattern space时,sed依照sed script 的编辑指令逐一对pattern space内的资料执行编辑,之後,再由pattern space内的结果送到标准输出,接着再将下一行资料读入.如此重执行上述动作,直至读>完所有资料行为止.

    小结,记住:

            (1)sed总是以行对输入进行处理

            (2)sed处理的不是原文件而是原文件的拷贝

命令行概述:

    sed 编辑指令的格式如下 :

              [address1[,address2]]function[argument]

其中 , 位址参数 address1 、address2 为行数或 regular expression 字串 , 表示所执行编辑的资料行; 函数参数 function[argument] 为 sed 的内定函数 , 表示执行的编辑动作。

有那些函数(function)参数

   下页表中介绍所有 sed 的函数参数(参照[chapter 4])的功能。

函数参数 功能

: label  建立 script file 内指令互相参考的位置。

#  建立解

{ }  集合有相同位址参数的指令。

!  不执行函数参数。

=  印出资料行数( line number )。

a/  添加使用者输入的资料。

b label  将执行的指令跳至由 : 建立的参考位置。

c/  以使用者输入的资料取代资料。

d  删除资料。

D  删除 pattern space 内第一个 newline 字母 / 前的资料。

g  拷贝资料从 hold space。

G  添加资料从 hold space 至 pattern space 。

h  拷贝资料从 pattern space 至 hold space 。

H  添加资料从 pattern space 至 hold space 。

l  印出 l 资料中的 nonprinting character 用 ASCII 码。

i/  插入添加使用者输入的资料行。

n  读入下一笔资料。

N  添加下一笔资料到 pattern space。

p  印出资料。

P  印出 pattern space 内第一个 newline 字母 / 前的资料。

q  跳出 sed 编辑。

r  读入它档内容。

s  替换字串。

t label  先执行一替换的编辑指令 , 如果替换成牛p>则将编辑指令跳至 : label 处执行。

w  写资料到它档内。

x  交换 hold space 与 pattern space 内容。

y  转换(transform)字元。

虽然 , sed 只有上表所述几个拥有基本编辑功能的函数 , 但由指令中位址参数和指令与指令间的配合 , 也能使sed 完成大部份的编辑任务。

2,1 删除

(1) sed -e '1d' inputfile (删除第一行)

    那么删除第x行呢?删除第x1,x2,x3行呢?

    sed -e 'xd' inputfile

    sed -e 'x1d' -e 'x2d' -e 'x3d' inputfile

    当然也许还有更好的办法。

(2) sed -e '1,3d' file (删除第一到第三行)

    思考:删除第n行到第m行?也就是

    sed -e 'n,md' file

    删除第一行到最后一行

    sed -e '1,$d' file     #$ 最后一行和一行的最后

(3) sed -e '/#/d' file  (删除含有'#'号的行)

    思考:删除含有字母xx的行

    sed -e '/xx/d' file

    思考: 删除除含有字符串xx的所有行

    sed -e '/xx/!d' file

(4) sed -e '/word1/, /word2/d' file  (删除从含有单词word1到含有单词word2的行)

    sed -e '10,/word1/d' file

    删除文件中从第10行到含有word1的行

    sed -e '/word1/,10/d' file

    和上面的匹配相反,删除从含有word1的行到第10行

(5) sed -e '/t.*t/d' file     (删除含有两个t的行)

    思考:删除含有指定正在表达式匹配的行。

2.2 替换      

Sed 可替换文件中的字串、资料行、甚至资料区。其中,表示替换字串的指令中的函数参数为s;表示替换资料行、或资料区>的指令中的函数参数为c。上述情况以下面三个例子说明。

*行的替换

(1) sed -e '1c/#!/bin/more' file (把第一行替换成#!/bin/more)

    思考: 把第n行替换成just do it

    sed -e 'nc/just do it' file

(2) sed -e '1,10c/I can do it' file  (把1到10行替换成一行:I can do it)

    思考: 换成两行(I can do it! Let's start)

    sed -e '1,10c/I can do it!/nLet'"/'"'s start' file

*字符的替换

(3) sed -e 's/word1/& word2/' file (将每一行的word1单词替换成s参数最多与两个位置参数相结合,函数参数s中有两个特殊的符号:

    & : 代表pattern

    /n : 代表 pattern 中被第 n 个 /( 、/)(参照[附录 A]) 所括起来的字串。例如

    sed -e 's/w1/& w2/' file  # w1的地方输出 w1 w2

    sed -e  's//(test/) /(my/) /(car/)/[/2 /3 /1]/' file   #结果: [my car test]

*flag 参数举例

    sed -e 's/w1/& w2/g' file

    g : 代表替换所有匹配项目;这里,文件中所有字符串w1都会被替换成字串w1 w2

    sed -e 's/w1/& w2/10' file

    m(10) : 替换行内第m个符合的字串; 记住,是行内的第m个匹配的字串

    sed -e 's/w1/& w2/p' file

    p : 替换第一个和w1匹配的字符串为w1 w2,并输出到标准输出.

    sed -e 's/w1/& w2/w w2file' file

    w filename : 该参数会将替换过的内容写入到文件w2file并输出替换后的整个文件。注意w2file里写的只是替换过的行。    sed 'e 's/w1/& w2/' file

    这里的flag 为空, 这样就只是将第一个w1匹配的字符串替换成w1 w2而后面的不进行替换。

*位置参数应用举例

    sed -e '/machine/s/phi/beta/g' file

    将文件中含"machine"字串的资料行中的"phi"字串,替换成为"beta"字串

    sed -e '1,10 s/w1/& w2/g' file

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

    sed -e '1,/else/ s/w1/& w2/g' file

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

其它位置参数的应用与前面的相同。

2.3 内容的插入

i

    基本格式:

    [address] i/ 插入内容 filename

word2)

说明:

函数参数 s 表示替换(substitute)文件内字串。其指令格式如下 :

[address1[ ,address2]] s/pattern/replacemen/[flag]

    sed -e '/#/i/words' file      #在#字符的前面插入一行words

说明:

    这里的函数参数是i,它只能有一个地址参数。

    sed -e '1/i/words' file

    在第一行前加一行words

    cat "word" | sed -e '/$/.doc/g'   #输出word.doc

    在word后面加上后缀名,从而输出word.doc

    i 参数正好与a参数相反,它是插入到所给内容的前面.

a

    a参数的使用格式如下:

    [address] a/ <插入内容> filename

    sed -e '/unix/a/ haha' test.txt   #在含有unix的行后添加"haha"

    #输出结果为:

        unix

        haha

    另外: sed -e '1 a/ hh' test.txt  #在第一行后添加hh字符.

2.4 文本的打印: p

    基本格式:

    [address1,[address2]] p

    (1) sed -e '/then/ p' filename  #打印所有行并重复打印含有then 的行

    (2) sed -n '/then/ p' filename  #只打印含有then的行

    (3) sed -e '1,3 p' filename     # 打印所有行并重复1-3行

    (4) sed -n '1,3 p' filename     # 打印1-3行

    (5) sed -n '/if/,/fi/ p' filename #打印字符if和fi之间的内容

    p函数为sed的打印函数,在这里要注意-e 和-n 参数的区别。一般使用-n参数。

2.5 字元的替换: y

    例如:

    (1)sed -e 'y/abc../xyz../' filename

    把文件中的a字母替换成x, b替换成y, c替换成z。

    (2) sed  -e 'y/abc/ABC' filename

    把小写的abc转换成大写的ABC

2.6 反相执行命令 : !

    基本格式:

    [address1[ , address2]] ! 函数参数

    sed -e '/1996/!d' filename

    删除除了含有1996的所有行。

2.7 改变文件中的资料: c

    基本格式:

    [address1[ ,address2]]c/ filename

    函数参数 c 紧接着 "/" 字元用来表示此行结束 , 使用者所输入的资料必须从下一行输入。如果资料超过一行 , 则须在>每行的结尾加入"/"

    sed -e '/zhengxh/c hhhh' filename

    表示把含有字符串zhengxh的行,该成hhhh。

2.8 读入下一行资料: n

    基本格式:

    [address1[ ,address2]] n

    sed -n -e '/echo/n' -e 'p' temp

    表示输出文件,但如果一行含有字符串echo,则输出包含该字符串的下一行。

    sed -n -e 'n' -e 'p' filename

    输出文中的偶数行

2.9 读入它档内容

sed -i 就是直接对文本文件进行操作的

sed -i 's/原字符串/新字符串/' /home/1.txtsed -i 's/原字符串/新字符串/g' /home/1.txt

这两条命令的区别就是,看示例吧

这是1.txt的内容

#cat 1.txt

d

ddd

#ff

再看执行这两条命令的区别吧

sed -i 's/d/7523/' /home/1.txt

执行结果7523

7523dd

#ff

sed -i 's/d/7523/g' /home/1.txt

执行结果7523752375237523

#ff

去掉 “行首” 带“@”的首字母@

sed -i 's/^@//' file

特定字符串的行前插入新行

sed -i '/特定字符串/i 新行字符串' file

特定字符串的行后插入新行

sed -i '/特定字符串/a 新行字符串' file

特定字符串的删除

sed -i '/字符串/d' file

3, 命令的复用

    一次执行多个命令的方式有三种:

    (1) sed 's/w1/& w2/g; 1/i/words' filename   (使用;号把命令隔开,注意前面不加-e参数)

    (2) sed -e 'cmd1' -e 'cmd2'  filename     (使用多个-e参数)

http://blog.csdn.net/zg_hover/article/details/1804481

sed -i 就是直接对文本文件进行操作的

sed -i 's/原字符串/新字符串/' /home/1.txtsed -i 's/原字符串/新字符串/g' /home/1.txt

这两条命令的区别就是,看示例吧

这是1.txt的内容

#cat 1.txt

d

ddd

#ff

再看执行这两条命令的区别吧

sed -i 's/d/7523/' /home/1.txt

执行结果7523

7523dd

#ff

sed -i 's/d/7523/g' /home/1.txt

执行结果7523752375237523

#ff

去掉 “行首” 带“@”的首字母@

sed -i 's/^@//' file

特定字符串的行前插入新行

sed -i '/特定字符串/i 新行字符串' file

特定字符串的行后插入新行

sed -i '/特定字符串/a 新行字符串' file

特定字符串的删除

sed -i '/字符串/d' file

给我留言

留言无头像?