sed总结

[-]

  1. 简介
  2. 调用方式
  3. 选项
  4. 命令集合
  5. 寻址方式
  6. 基本用法
  7. 文件操作
  8. 附加-插入-修改文本
  9. 删除文本
  10. 替换文本
  11. 转换文本
  12. 补充

--------------------------------------------

简介

简介<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

一个“非交互式的”字符流编辑器(stream editor)

Sed是一非交互性文本编辑器,它编辑文件或标准输入导出的文本拷贝,标准输入可能来自键盘、文件、重定向、字符串、变量或一管道文件

 

sed主要用来自动编辑一个或多个文件(替换、插入、删除、追加、更改……);简化对文件的反复操作;编写转换程序等

 

【对进入的数据进行全局的处理,增加,删除,修改某些部分,得出结果】

处理过程

1.处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space)

2.接着用sed命令处理缓冲区中的内容,

3.处理完成后,把缓冲区的内容送往屏幕。

4.接着处理下一行或多行,这样不断重复,直到文件末尾

 

文件内容并没有改变,除非你使用重定向或写入命令存储输出

主要作用:

  1. 抽取域
  2. 匹配正则表达式
  3. 比较域
  4. 增加、附加、替换

 

 

调用方式

调用方式:

  1. 命令行输入

sed [options] 'command' file(s)

  1. 使用sed脚本

sed [options] -f scriptfile file(s)

  1. 使sed脚本可执行

在脚本第一行具有sed命令解释器

Sed脚本文件 [选项]输入文件

sed–f sedScriptFile targetFile

 

选项

选项:

-n

--quiet, --silent 取消默认输出

不打印,不写编辑行到标准输出,缺省情况下打印所有行[编辑/未编

辑]p命令可以打印编辑行

-f

调用sed脚本sed –f sedScriptFile targetFile

-c

下一命令是编辑命令,使用多项编辑时加入此选项

-e command

--expression=command   允许多条编辑命令

-h

--help打印帮助,并显示bug列表的地址

-V

--version 打印版本和版权信息

 

命令集合

命令集合:

a\

定位行号后附加新文本信息 append

b lable

分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾

c\

用新的文本改变本行的文本,用新文本替换定位文本  change

d

从模板块(Pattern space)位置删除行  删除定位行  delete

D

删除模板块的第一行

i\

定位行号后插入  insert

h

拷贝模板块的内容到内存中的缓冲区

H

追加模板块的内容到内存中的缓冲区

g

获得内存缓冲区的内容,并替代当前模板块中的文本

获得内存缓冲区的内容,并追加到当前模板块文本的后面

l

列表不能打印字符的清单 将非打印字符显示为两个数字的ASCII代码

n

读取下一个输入行,用下一个命令处理新的行而不是用第一个命令

追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码

打印匹配行 print

P(大写)

打印模板块的第一行

退出Sed  第一个模式匹配完成后退出或立即退出

r file

从file中读行  从另一个文件中读文本 read

t label 

if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾

T label

错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾

w file

写并追加模板块到file末尾 写文本到一个文件  write

W file

写并追加模板块的第一行到file末尾

y

传送字符

!

表示后面的命令对所有没有被选定的行发生作用

s/re/string 

用string替换正则表达式re  使用替换模式替换相应模式

=

打印匹配行行号

把注释扩展到下一个换行符以前

{}

定位执行命令组

替换标记

1)g表示行内全面替换。   

2)p表示打印行。   

3)w表示把行写入一个文件。   

4)x表示互换模板块中的文本和缓冲区中的文本。   

5)y表示把一个字符翻译为另外的字符(但是不用于正则表达式)

 

寻址方式

寻址:

sed命令可以指定零个、一个或两个地址。每个地址都是一个描述模式、行号、或者行寻址

符号的正则表达式。

如果没有指定地址,那么命令将应用于每一行。

如果只有一个地址,那么命令将应用于与这个地址匹配的任意行。

如果指定了由逗号分隔的两个地址,那么命令应用于匹配第一个地址的第一行和他后面的

行,直到匹配第二个地址的行(包括此行)。

 

如果地址后面跟有感叹号(!),那么命令就应用于不匹配该地址的所有的行。

定位命令

x

行x

X,y

行x到行y

/pattern/

模式

/pattern/pattern/

两个模式

/pattern/,x

 

模式+行【在给定行号上查询模式】

X,y /pattern/

通过行号和模式查询匹配行

X,y!

不包含指定行号

 

基本用法

示例:[dream为数据文件]

基本用法——匹配&打印

  1. 显示第二行

$sed –n ‘2p’ dream

  1. 显示一到三行

$sed –n ‘1,3p’ dream

  1. 匹配模式

$sed –n ‘/dreamb/’p dream

  1. 使用模式和行号进行匹配

$sed –n ‘4,/The/’p dream

【只能加一个行号,不能变为区间】

  1. 打印匹配行行号

$sed –n ‘/dream/=’ dream

  1. 匹配元字符

$sed –n ‘/\$/’p dream

  1. 显示整个文件

$sed –n ‘1,$p’ dream

  1. 匹配字符串

$sed –n ‘/.*ing/’p dream

  1. 首行

$sed –n ‘1p’ dream

10.行号打印

$sed –e ‘/music/=’ quote.txt  整个文件并打印匹配行号

$sed –n ‘/music/=’ quote.txt  只打印匹配行号

sed –n “/^title/p” auction.xml#精确匹配以title开头,打印此行

sed -n "/pict/,5p" auction.xml #指定具体行匹配

sed –n “/\<doc\>/p” auction.xml #匹配正则表达式

sed –n “/.*is/p” auction.xml#匹配任意字母

sed -n -e "/^title/p" -e "/^title/=" auction.xml #打印行号及匹配行

 

文件操作

文件读入写出

 

读取文件:r命令

$ sed '/test/r file' example

file里的内容被读进来,显示在与test匹配的行后面,如果匹配多行,则file的内容将显示在所有匹配行的下面。   

 

写入文件:w命令   可以使用重定向

$ sed -n '/test/w file' example

在example中所有包含test的行都被写入file里

 

注: 在命令和文件名之间必须有一个空格。每个脚本最多只能打开10个文件

 

附加-插入-修改文本

附加/插入/修改文本

使用符号a\,可以将指定文本一行或多行附加到指定行,若不指定放置位置,默认放入第一行。

注:附加操作,结果到标准输出,不能被编辑,必须存到另一个文件,再运行一个sed编辑

插入文本 i\   修改文本 c\

 

  1. 匹配行后插入一行

$sed ‘/dreamb/a\”appended line”’ dream

【会自动换行】

  1. 插入文本

$sed ‘2 i\ “inserted line”’ dream

【在第二行之前加一行】

sed "/user/ i\test" auction.xml

在匹配行前插入test

  1. 修改文本

$sed ‘3 c\ “changed line”’ dream

【整行替换掉】

【注:可以用行,/正则/搞定】

 

删除文本

删除文本

命令格式:  [address[,address]] d

  1. 删除行

$sed ‘1d’ dream

$sed ‘1,3d’ dream

$ sed '2,$d' example  #第二行到末尾所有行

$ sed '$d' example-----删除example文件的最后一行

  1. 删除匹配行

$sed ‘/dreamb/d’ dream

    $sed –n ‘/BEGIN/,/END/d’ myfile

 

替换文本

替换文本

格式:[address[,address]]s/pattern-find/replacement-pattern/[g,p,w,n]

n   1到512之间的一个数字,表示对本模式中指定模式第n次出现的情况进行替换。

g   对模式空间所有出现的情况进行全局更改【缺省只替换首次出现的模式 】

p   打印模式空间的内容

w   file

  1. 替换

$sed ‘s/dreamb/DREAMB’ dream

【问题:这里是如何执行的?报错】

  1. 全局替换

$sed ‘s/The/Wow!/g’ dream

  1. 替换后重定向到文本

$sed ‘s/dreamb/Dream/w sed.out’ dream

【只输出替换行】

  1. 读取部分写入另一个文件

$sed ‘1,2 w filedt’ dream

$sed ‘/dream/ w filedt’ dream

【注: 在命令和文件名之间必须有一个空格。每个脚本最多只能打开10个文件。】

  1. 首次匹配后退出

$sed ‘/dream/q’ dream

【遇到匹配之前的内容还是要输出的】

  1. 显示文件中的控制字符

格式: [ address[,address]]l

$sed –n ‘1,$l’ dream  【小写字母l】

  1. 去除行首数字

$sed ‘s/^[0-9]//g’ dream

  1. Shell向sed传值

$NAME=”go there”

$REP=”GO”

$echo $NAME | sed “s/go/$REP/g”      这里必须双引号【此时sed单引号不被解析】

  1. 使用替换修改字符串(title前面加test)(注意和附件文本不要混淆)

sed -n "s/^title/test &/p" auction.xml

  1. $ sed 's#10#100#g' example

不论什么字符,紧跟着s命令的都被认为是新的分隔符,所以,“#”在这里是分隔符,代替了默认的“/”分隔符。表示把所有10替换成100

  1. $ sed 's/^192.168.0.1/&localhost/' example

&符号表示替换换字符串中被找到的部份。所有以192.168.0.1开头的行都会被替换成它自已加 localhost,变成192.168.0.1localhost

 

转换文本

转换文本

语法: [address]y/abc/xyz/

功能:字母表式的转换

eg1

$ cat test.txt

1 cow

2 cow

3 pig

4 cow

$ sed 'y/cp/wd/' test.txt

1 wow

2 wow

3 dig

4 wow

(c转换成w,p转换成d)

 

eg2

$ sed '1,10y/abcde/ABCDE/' example

把1--10行内所有abcde转变为大写,注意,正则表达式元字符不能使用这个命令

 

补充

sed补充:

分组

sed 使用大括号“{}”将一个地址嵌套在另一个地址中,或者在相同的地址上应用多个命令。

 

左大括号必须在行末,而且右大括号本身必须单独占一行。要确保在大括号之后没有空格。

可以使用大括号将编辑命令括起来以对某个范围的行应用多个命令。

 

$cat test.txt

1 cow

2 cow

3 pig

4 cow

$ cat test.sed

/^1/,/^3/{

       s/cow/pig/

       /^2/d

}

$ sed -f test.sed test.txt

1 pig

3 pig

4 cow

 

输出到不同文件:

/^1/,/^3/{

       /^1/w 1out.txt

       /^2/w 2out.txt

       /^1/,/^3/w allout.txt

}

下一个

sed '/test/{ n; s/aa/bb/; }' example

如果test被匹配,则移动到匹配行的下一行,替换这一行的aa,变为bb,并打印该行,然后继续

 

退出

$ 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 -e '1,5d' -e 's/test/check/' example

(-e)选项允许在同一行里执行多条命令。如例子所示,第一条命令删除1至5行,第二条命令用check替换test。命令的执 行顺序对结果有影响。如果两个命令都是替换命令,那么第一个替换命令将影响第二个替换命令的结果。   

 

$ sed --expression='s/test/check/' --expression='/love/d' example

 

简单脚本示例

vi test.sed

s/pig/cow/g

[:~$] sed -f test.sed test.txt

cow

[:~$] cat test.txt

pig

 

简单脚本示例:

[:~$] cat test.sh

 

sed '/^1/,/^3/{

s/cow/pig/

}' test.txt

[:~$] ./test.sh   

1 pig

2 pig

3 pig

4 cow

 

posted @ 2014-05-17 14:34  TonyChai  阅读(334)  评论(0编辑  收藏  举报