sed 采用的是流编辑模式,最明显的特点是,在 sed 处理数据之前,需要预先提供一组规则,sed 会按照此规则来编辑数据。
sed 会根据脚本命令来处理文本文件中的数据,这些命令要么从命令行中输入,要么存储在一个文本文件中,此命令执行数据的顺序如下:
- 每次仅读取一行内容;(表示规则是根据一行一行的数据来执行的)
- 根据提供的规则命令匹配并修改数据。注意,sed 默认不会直接修改源文件数据,而是会将数据复制到缓冲区中,修改也仅限于缓冲区中的数据;
- 将执行结果输出。
当一行数据匹配完成后,它会继续读取下一行数据,并重复这个过程,直到将文件中所有数据处理完毕。
基本格式
sed 命令的基本格式:
sed [选项] [脚本命令] 文件名
| 选项 | 含义 |
|---|---|
| -e 脚本命令 | 该选项会将其后跟的脚本命令添加到已有的命令中。 |
| -f 脚本命令文件 | 该选项会将其后文件中的脚本命令添加到已有的命令中。 |
| -n | 默认情况下,sed 会在所有的脚本指定执行完毕后,会自动输出处理后的内容,而该选项会屏蔽启动输出,需使用 print 命令来完成输出。 |
| -i | 此选项会直接修改源文件,要慎用。(但一般都是用它的) |
sed s命令
命令基本格式:[address]s/pattern/replacement/flags
| flags 标记 | 功能 |
|---|---|
| n | 1~512 之间的数字,表示指定要替换的字符串出现第几次时才进行替换,例如,一行中有 3 个 A,但用户只想替换第二个 A,这是就用到这个标记; |
| g | 对数据中所有匹配到的内容进行替换,如果没有 g,则只会在第一次匹配成功时做替换操作。例如,一行数据中有 3 个 A,则只会替换第一个 A; |
| p | 会打印与替换命令中指定的模式匹配的行。此标记通常与 -n 选项一起使用。 |
| w file | 将缓冲区中的内容写到指定的 file 文件中; |
| & | 用正则表达式匹配的内容进行替换; |
| \n | 匹配第 n 个子串,该子串之前在 pattern 中用 () 指定。 |
| \ | 转义(转义替换部分包含:&、\ 等)。 |
aaa.txt文件内容:
card card is card card
card card is card card
card card is card card
输入
sed -i 's/card/fire/g' aaa.txt
aaa.txt文件的内容
fire fire is fire fire
fire fire is fire fire
fire fire is fire fire
我们知道,-n 选项会禁止 sed 输出,但 p 标记会输出修改过的行,将二者匹配使用的效果就是只输出被替换命令修改过的行,例如: 此时aaa.txt内容为
fire fire is fire fire
fire is horrible
fire fire fire !!!
执行sed -n 's/fire/change/p' aaa.txt
输出内容,因为没有写-i参数,所以不会修改到aaa.txt文件的内容
如果写-i参数,p标志会失去作用
w 标记会将匹配后的结果保存到指定文件中,此时aaa.txt文件内容为:
This is a trial line.
This is a different line.
执行sed 's/trial/test/w test.txt' aaa.txt
会创建一个text.txt文件,内容为
This is a test line.
总结
sed命令还有很多用法,我觉得最实用的就是sed s命令,其他的不太常用,适用场景太少,不值得记住。