linux中sed命令的使用与注意小结
前言
sed是一种流编辑器,它是文本处理中非常有用的工具,能够完美的配合正则表达式使用,功能不同凡响。处理时,把当前处理的行存储在临时缓冲区中,称为『模式空间』(patternspace),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。sed主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序等。
sed的用法
$sed[-nefr][动作]
参数:
- -n:使用安静模式。在一般sed用法中,所有来自STDIN的数据一般都会被列出到屏幕上。但如果加上-n参数后,则只有经过sed特殊处理的那一行(或者操作)才会被列出来。
- -e:直接在命令行模式上进行sed的动作编辑。(默认)
- -f:直接将sed的动作写在一个文件内,-ffilename则可以执行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'2ahahaha'text#在第二行后加上“hahaha”字样 $sed'2ahahaha\ >xixixi'text#在第二行后加上两行字 $sed'2,5cNo2-5number'text#将第2~5行的内容替换成为“No2-5number”,是整行替换 $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参数要慎用,它会直接修改读取的文件内容。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。