shell基础九:sed
时间:2006-06-19 来源:aixcq
sed
sed 用法介绍
s e d是一个非交互性文本流编辑器。它编辑文件或标准输入导出的文本拷贝。
引用: |
• 抽取域。 |
可以在命令行输入s e d命令,也可以在一个文件中写入命令,然后调用s e d,这与a w k基本相同。使用s e d需要记住的一个重要事实是,无论命令是什么, s e d并不与初始化文件打交道,它操作的只是一个拷贝,然后所有的改动如果没有重定向到一个文件,将输出到屏幕。
因为s e d是一个非交互性编辑器,必须通过行号或正则表达式指定要改变的文本行。
本文介绍s e d用法和功能。本章大多编写的是一行命令和小脚本。这样做可以慢慢加深对s e d用法的了解,取得宝贵的经验,以便最终自己编出大的复杂s e d脚本。
和g r e p与a w k一样, s e d是一种重要的文本过滤工具,或者使用一行命令或者使用管道与g r e p与a w k相结合。
1 sed怎样读取数据
s e d从文件的一个文本行或从标准输入的几种格式中读取数据,将之拷贝到一个编辑缓冲区,然后读命令行或脚本的第一条命令,并使用这些命令查找模式或定位行号编辑它。重复此过程直到命令结束。
2 调用sed
调用s e d有三种方式:在命令行键入命令;将s e d命令插入脚本文件,然后调用s e d;将s e d命令插入脚本文件,并使s e d脚本可执行。
使用s e d命令行格式为:
代码: |
sed [选项] s e d命令输入文件。 |
记住在命令行使用s e d命令时,实际命令要加单引号。s e d也允许加双引号。
使用s e d脚本文件,格式为:
代码: |
sed [选项] -f sed脚本文件输入文件 |
要使用第一行具有s e d命令解释器的s e d脚本文件,其格式为:
代码: |
s e d脚本文件[选项] 输入文件 |
不管是使用s h e l l命令行方式或脚本文件方式,如果没有指定输入文件, s e d从标准输入中接受输入,一般是键盘或重定向结果。
引用: |
s e d选项如下: |
2.1 保存sed输出
由于不接触初始化文件,如果想要保存改动内容,简单地将所有输出重定向到一个文件即可。下面的例子重定向s e d命令的所有输出至文件‘ m y o u t f i l e’,当对结果很满意时使用这种方法。
代码: |
$sed 'some-sed-commands' input-file > myoutfile |
2.2 使用sed在文件中查询文本的方式
s e d浏览输入文件时,缺省从第一行开始,有两种方式定位文本:
引用: |
1) 使用行号,可以是一个简单数字,或是一个行号范围。 |
下面是使用s e d定位文本的一些方式。
代码: |
x x为一行号,如1 |
2.3 基本sed编辑命令
代码: |
sed编辑命令 |
sed和正则表达式
s e d识别任何基本正则表达式和模式及其行匹配规则。记住规则之一是:如果要定位一特殊字符,必须使用( \)屏蔽其特殊含义
_________________
s e d例子中使用下述文本文件q u o t e . t x t。
代码: |
[sam@Linux_chenwy sam]$ cat quote.txt |
1 使用p(rint)显示行
只打印第二行,用-n
代码: |
[sam@Linux_chenwy sam]$ sed -n '2p' quote.txt |
2 打印范围
可以指定行的范围,现打印1到3行,用逗号分隔行号。
代码: |
[sam@Linux_chenwy sam]$ sed -n '1,3p' quote.txt |
3 打印模式
假定要匹配单词N e a v e,并打印此行,方法如下。使用模式/ p a t t e r n /格式,这里为/ N e a v e /。
代码: |
[sam@Linux_chenwy sam]$ sed -n '/The/p' quote.txt |
4 使用模式和行号进行查询
可以将行号和模式结合使用。假定要改动文件q u o t e . t x t最后一行中的单词t h e,使用s e d查询t h e,返回两行:
代码: |
[sam@Linux_chenwy sam]$ sed -n '/The/p' quote.txt |
使用模式与行号的混合方式可以剔除第一行,格式为l i n e _ n u m b e r, / p a t t e r n /。逗号用来分隔行号与模式开始部分。为达到预期结果,使用4 , / t h e /。意即只在第四行查询模式t h e,命令如下:
代码: |
[sam@Linux_chenwy sam]$ sed -n '4,/The/p' quote.txt |
上面有错,其实是把第四行后的都打出来了
这个模式应该哪果指定行找不到符合条件的,就从下一行开始查找,直到找到为止,并把,找到行之前的全部打打印出来。
如果指定行本身就符合条伯,把本行及后面的行的全部打印出来
5 匹配元字符
匹配元字符$前,必须使用反斜线\屏蔽其特殊含义。模式为/\$/ p。
代码: |
[sam@Linux_chenwy sam]$ sed -n '/\$/p' quote.txt |
6 显示整个文件
要打印整个文件,只需将行范围设为第一行到最后一行1 , $。$意为最后一行。
代码: |
[sam@Linux_chenwy sam]$ sed -n '1,$p' quote.txt |
7 任意字符
匹配任意字母,后跟任意字母的0次或多次重复,并以i n g结尾,模式为/ . * i n g /。可以使用这个模式查询以i n g结尾的任意单词。
代码: |
[sam@Linux_chenwy sam]$ sed -n '/.*ing/p' quote.txt |
8 首行
要打印文件第一行,使用行号:
代码: |
[sam@Linux_chenwy sam]$ sed -n '1p' quote.txt |
9 最后一行
要打印最后一行,使用$。$是代表最后一行的元字符。
代码: |
[sam@Linux_chenwy sam]$ sed -n '$p' quote.txt |
10 打印行号
要打印行号,使用等号=。打印模式匹配的行号,使用格式/ p a t t e r n / =。
代码: |
[sam@Linux_chenwy sam]$ sed -e '/music/=' quote.txt |
整个文件都打印出来,并且匹配行打印了行号。如果只关心实际行号,使用- e选项。
代码: |
[sam@Linux_chenwy sam]$ sed -n '/music/=' quote.txt |
如果只打印行号及匹配行,必须使用两个s e d命令,并使用e选项。第一个命令打印模式匹配行,第二个使用=选项打印行号,格式为sed -n -e /pattern/p -e /pattern/=
代码: |
[sam@Linux_chenwy sam]$ sed -n -e '/music/p' -e '/music/=' quote.txt |
_________________