前言
sed是一种流编辑器,它是文本处理中非常有用的工具,能够完美的配合正则表达式使用,功能不同凡响。处理时,把当前处理的行存储在临时缓冲区中,称为『模式空间』(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。sed主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序等。
sed的用法
$ sed [-nefr] [动作]
参数:
- -n : 使用安静模式。在一般sed用法中,所有来自STDIN的数据一般都会被列出到屏幕上。但如果加上-n参数后,则只有经过sed特殊处理的那一行(或者操作)才会被列出来。
- -e : 直接在命令行模式上进行sed的动作编辑。(默认)
- -f : 直接将sed的动作写在一个文件内,
-f filename
则可以执行filename内的sed动作。 - -r : sed的动作支持的是扩展型正则表达式的语法(默认是基础正则表达式语法)。
- -i : 直接修改读取的文件内容,而不是屏幕输出。
默认情况下sed不直接作用于读取的文件中
动作说明: [n1[,n2]] function
- n1,n2 : 不见得会存在,一般代表选择进行动作的行数,举例来说,如果我的动作是需要在10到20行之间进行的,则“10,20[动作行为]”。
function 有下面的这些参数:
- a : 新增到下一行,后面可以接字符串
- c : 替换,后面可以接字符串
- d : 删除,后面不接热河参数
- i : 插入到上一行,后面可接字符串
- p : 打印,通常会与参数 sed -n 一起运行
- s : 查找并替换特定字符串,通常搭配正则表达式。
例如,1,20s/old/new/g
演示
//假设有text文件 $ sed '2,5d' text #将第2~5行删除 $ sed '2a hahaha' text #在第二行后加上“hahaha”字样 $ sed '2a hahaha\ > xixixi' text #在第二行后加上两行字 $ sed '2,5c No 2-5 number' text #将第2~5行的内容替换成为“No 2-5 number”,是整行替换 $ sed -n '5,7p' text #将5~7行打印出来,一定要加 -n $ sed 's/hahaha/ssss/g' text #将hahaha字段替换成ssss,这是部分数据的查找并替换
sed还可以和正则表达式配合使用
如:
$ sed 's/^h/ssss/g' text #将h开头的字段替换成ssss
注意
- sed后面接的动作,务必以两个单引号括住。
- 使用p(打印)参数时,sed一定要用-n,否则所有的行都会被输出,这样就没有意义了。
- sed默认不直接作用于读取的文件中。
- -i参数要慎用,它会直接修改读取的文件内容。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。