功能说明:利用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