看到这些使用, 不是很理解
sed '/^Hello/w test.txt' demo.txt
sed '/^Hello/r ad.txt' demo.txt
sed '2,$s/Hello/cat/' demo.txt 从第二行开始的所有行
真正理解是在这里开始的
sed '/^Hello/s/Hello/cat/' demo.txt
sed 里面有各自子命令, 比如 s 查找替换, w 写入到一个文件中, r 读取一个文件并插入, a 后面加内容, i 在前加
格式是 sed [option] '/[pattern]/[address]cmd'
cmd
其中 cmd 就是子命令, 子命令必须存在, 比如 sed ‘/Hello/’ demo.txt 会提示遗漏命令,
引号内容可以理解为新的命令行, 因此子命令也是有参数的, /[pattern] 是输入给 sed 本身进行解析的正则文本, 解析之后它可以作为子命令的输入进行进一步处理
比如 sed '/Hello/=' demo.txt
表示将匹配到包含 Hello 的所有行传递给 =
命令, = 命令会输出该行的行号。
pattern
pattern
部分可以省略, 若省略了该部分, 则子命令的输入就是整个文本,
比如 s 替换命令, 他需要输入两个参数, 一个是 pattern, 一个是 replace, 还有一个可选的 option
即 s/pattern/replace/[option]
, 例如 sed 's/Hello/cat/g' demo.txt
像 sed '/^Hello/s/Hello/cat/' demo.txt
表示 sed 先对输入文本进行查找 ^Hello
, 将查找到的行再传递给s
子命令, 子命令根据输入的行进行查找替换
对于 s
子命令来说, 其本身具有查找功能了, 实际往往不需要前面的匹配, 但是对于 a, i 等命令, 它只处理给定的行, 这时候就这样
sed '/^Hello/a Befor Hello' demo.txt
对于输入的行, a 命令将在它的前面插入新的一行,
sed '/^Hello/r ad.txt' demo.txt
对于输入的行, r 命令将在其后插入从文件中读取的文本
address
命令之前还有 address
可选项, 就是用来给定范围的, 比如只对给定的输入行的某一行进行更改
sed '2a Good' demo.txt
将 Good 插入第二行之后, 也可以是一个范围比如 2,10a
, $
代表末尾, 从而 2,$
表示从第二行开始的所有行, 比如
sed '2,$s/Hello/cat/' demo.txt
从第二行开始的所有行中的Hello替换成cat
option
最外面的 option
用来提供附加选项, 比如 -i 写入文件, -n 不打印内容
sed 默认不会立刻写入文件, 而是在缓冲区进行匹配替换等, 然后打印到标准输出, -i 表示执行后将内容写入到文件中了, 一般可以先在终端预览,觉得没问题后再加上 -i 写入文件