Linux sed 命令详解


功能说明:利用script来处理文本文件。 sed可依照script的指令,来处理、编辑文本文件。

简介:sed是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(patternspace),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。

两种形式:
1、sed [options] '{command}' file(s)

2、sed [options] -f scriptfile file(s)

方法1:
sed -i 's/被替换的内容/要替换成的内容/' file
方法2:
sed 's/被替换的内容/要替换成的内容/g' file > file.out
mv file.out file
参  数: 
a\ 在当前行后面加入一行文本。
b lable 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾。
c\ 用新的文本改变本行的文本。
d 从模板块(Pattern space)位置删除行。
D 删除模板块的第一行。
i\ 在当前行上面插入文本。
h 拷贝模板块的内容到内存中的缓冲区。
H 追加模板块的内容到内存中的缓冲区
g 获得内存缓冲区的内容,并替代当前模板块中的文本。
G 获得内存缓冲区的内容,并追加到当前模板块文本的后面。
l 列表不能打印字符的清单。
n 读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。
N 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码。
p 打印模板块的行。
P(大写) 打印模板块的第一行。
q 退出Sed。
r file 从file中读行。
t label if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。
T label 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。
w file 写并追加模板块到file末尾。
W file 写并追加模板块的第一行到file末尾。
! 表示后面的命令对所有没有被选定的行发生作用。
s/re/string 用string替换正则表达式re。
= 打印当前行号码。
# 把注释扩展到下一个换行符以前。
以下的是替换标记
g表示行内全面替换。
p表示打印行。
w表示把行写入一个文件。
x表示互换模板块中的文本和缓冲区中的文本。
y表示把一个字符翻译为另外的字符(但是不用于正则表达式)
选项:
-e进行多项编辑,即对输入行应用多条sed命令时使用
-n取消默认的输出
-f指定sed脚本的文件名
元字符集:
^行首定位符,/^my/ 匹配所有以my开头的行
$行尾定位符,/my$/ 匹配所有以my结尾的行
.匹配除换行符以外的单个字符,/m..y/ 匹配包含字母m,后跟两个任意字符,再跟字母y的行
*匹配零个或多个前导字符,/my*/ 匹配包含字母m,后跟零个或多个y字母的行
[]匹配指定字符组内的任一字符,/[Mm]y/ 匹配包含My或my的行
[^]匹配不在指定字符组内的任一字符,/[^Mm]y/ 匹配包含y,但y之前的那个字符不是M或m的行
\(..\)保存已匹配的字符,1,20s/\(you\)self/\1r/ 标记元字符之间的模式,并将其保存为标签1,之后可以使用\1来引用它。最多可以定义9个标签,从左边开始编号,最左边的是第一个。此例中,对第1到第20行进行处理,you被保存为标签1,如果发现youself,则替换为your。
&保存查找串以便在替换串中引用,s/my/**&**/ 符号&代表查找串。my将被替换为**my**
\<词首定位符,/\<my/ 匹配包含以my开头的单词的行
\>词尾定位符,/my\>/ 匹配包含以my结尾的单词的行
删除:
    sed '2d' example-----删除example文件的第二行。
    sed '2,$d' example-----删除example文件的第二行到末尾所有行。
    sed -e '1,3d' example-----(删除第一到第三行)
    sed '$d' example-----删除example文件的最后一行。
    sed '/test/'d example-----删除example文件所有包含test的行。sed -e '/#/d' example-----(删除含有'#'号的行)
    删除行首空格 
    sed ’s/^[ ]*//g’ filename 
    sed ‘s/^ *//g’ filename 
    sed ‘s/^[[:space:]]*//g’ filename 
替换:
    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/\(love\)able/\1rs/p' example-----love被标记为1,所有loveable会被替换成lovers,而且替换的行会被打印出来。
    sed 's#10#100#g' example-----不论什么字符,紧跟着s命令的都被认为是新的分隔符,所以,“#”在这里是分隔符,代替了默认的“/”分隔符。表示把所有10替换成100。
sed -e '1c\#!/bin/more' example-----(把第一行替换成#!/bin/more)
sed -e 's/word1/& word2/' example-----(将每一行的word1单词替换成s参数最多与两个位置参数相结合,函数参数s中有两个特殊的符号:& : 代表pattern
插入:
    行后和行前添加新行 
    行后:sed ‘s/pattern/&\n/g’ filename 
    行前:sed ‘s/pattern/\n&/g’ filename 
    &代表pattern 
    在第一行前插入文本 
    sed -i ’1 i\插入字符串’ filename 
    在最后一行插入 
    sed -i ‘$ a\插入字符串’ filename 
    在匹配行前插入 
    sed -i ‘/pattern/ i “插入字符串”‘ filename 
    在匹配行后插入 
    sed -i ‘/pattern/ a “插入字符串”‘ filename 

相关内容