Linux中sed编辑器概述及操作实例

sed编辑器

sed是一种流编辑器,流编辑器会在编辑器处理数据之前基于预先提供的一组规则来编辑数据流。

sed编辑器可以根据命令来处理数据流中的数据,这些命令要么从命令行中输入,要么存储在一个命令文本文件中。

(1)工作原理及流程

sed 的工作流程主要包括读取、执行和显示三个过程:

  • 读取:sed 从输入流(文件、管道、标准输入)中读取一行内容并存储到临时的缓冲区中(又称模式空间,pattern space)。
  • 执行:默认情况下,所有的sed 命令都在模式空间中顺序地执行,除非指定了行的地址,否则sed 命令 将会在所有的行上依次执行。
  • 显示:发送修改后的内容到输出流。在发送数据后,模式空间将会被清空。在所有的文件内容都被处理完成之前,上述过程将重复执行,直至所有内容被处理完。
  • 在所有的文件内容都被处理完成之前,上述过程将重复执行,直至所有内容被处理完。

注意:默认情况下所有的sed命令都是在模式空间内执行的,因此输入的文件并不会发生任何变化,除非是用重定向存储输出。

(2)命令使用

命令格式:

sed -e '操作' 文件1 文件2 ...
sed -n -e '操作' 文件1 文件2 ...
sed -f 脚本文件 文件1 文件2 ...
sed -i -e '操作' 文件1 文件2 ...

常用选项:
-e:表示用指定命令来处理输入的文本文件,只有一个操作命令时可省略,一般在执行多个操作命令使用
-f:表示用指定的脚本文件来处理输入的文本文件。
-h:显示帮助。
-n:禁止sed编辑器输出,但可以与p命令一起使用完成输出。
-i:直接修改目标文本文件。

常用操作:
s:替换,替换指定字符。
d:删除,删除选定的行。
a:增加,在当前行下面增加一行指定内容。
i:插入,在选定行上面插入一行指定内容。
c:替换,将选定行替换为指定内容。
y:字符转换,转换前后的字符长度必须相同。
p:打印,如果同时指定行,表示打印指定行;如果不指定行,则表示打印所有内容;如果有非打印字符,则以 ASCII 码输出。其通常与“-n”选项一起使用。
=:打印行号。
l:打印数据流中的文本和不可打印的ASCII字符(比如结束符$、制表符\t)

例:

sed -n -e 'p' 文件名    ##打印当前文件所有内容

在这里插入图片描述

sed -n -e '=' 文件名    ##打印文件内容行数

在这里插入图片描述

sed -n '
> =
> p
> ' 文件名

在这里插入图片描述

(3)使用地址实例

sed编辑器有2种寻址方式:

  • 以数字形式表示行区间

  • 用文本模式来过滤出行

例:
在这里插入图片描述

(4)删除行实例

在这里插入图片描述

(5)替换内容实例

行范围 s/旧字符串/新字符串/替换标记

4种替换标记:
数字:表明新字符串将替换第几处匹配的地方
g:表明新字符串将会替换所有匹配的地方
p:打印与替换命令匹配的行,与-n一起使用
w 文件:将替换的结果写到文件中

在这里插入图片描述

(6)插入实例

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_51468875/article/details/111797590