在日常使用 Linux 系统的过程中,sed 命令堪称文本处理的利器,尤其在替换文本内容方面几乎每天都会用到。今天我们就系统梳理 sed 替换操作的几种常见模式,把这些核心用法搞明白,后续操作会更得心应手。
具体来说,你需要掌握以下几种场景:
1)仅替换首次匹配到的内容
2)全局替换所有匹配项
3)替换指定整行的内容
4)替换连续多行的内容
5)将替换结果直接写回原文件
6)一次执行多个不同的替换操作
7)利用正则表达式实现复杂替换
替换首次搜索到的内容
这是最基本的 sed 替换用法。命令格式为:
sed 's/要替换的内容/新的内容/' 要处理的文件
它的特点是只替换每一行中第一个匹配到目标字符串。举个例子,下面的命令将每行第一个小写字母 b 替换为大写 B,而该行后面其他位置的 b 则不会被改变。

全局替换所有匹配的内容
如果你希望将文件中所有符合条件的目标都替换掉,需要在命令末尾加上 g(global 的缩写):
sed 's/要替换的内容/新的内容/g' 要处理的文件
效果立竿见影,所有小写 b 都会被替换为大写 B,每一行都不会遗漏。

替换某一整行的内容
有时我们不需要逐字符替换,而是想把某一行整体替换成新文本。这时可以使用 c(change 的缩写)指令:
sed '行号c 新的内容' 要处理的文件
比如将第二行的内容整个改为"new test!",操作如下。

替换多行区域的内容
如果你需要将起始行到结束行之间的整个区间替换成同一段文本,格式非常简洁:
sed '起始行号,终止行号c 新的内容' 要处理的文件
下面这个例子将第 2 行到第 6 行的所有内容统一替换为"new test!"。

将替换结果保存到原文件
以上所有操作默认只将替换后的结果输出到屏幕,并不会修改原始文件。如果希望一次性把更改写回原文件,只需加上 -i 参数:
sed -i 's/要替换的内容/新的内容/g' 要处理的文件

同时执行多个替换操作
多个 sed 命令可以通过 -e 参数串联起来,实现一次批量处理。下面这个例子先执行一次替换(将小写 a 变为大写 A),接着又把第二行的内容改成"new test!"。

结合正则表达式进行替换
sed 的强大之处还在于,替换与被替换的部分都可以使用正则表达式。举例来说,想把文件中所有数字都替换成"好的",可以这样写:
sed 's/[0-9]/好的/g' testFile2.txt

使用 sed 时有一个细节需要格外留意:输入命令之前务必确认输入法已切换为英文半角状态。从 Windows 复制命令到 Linux 终端时,经常因格式不一致导致执行报错,此时手工重新输入一遍往往最稳妥。如果嫌麻烦,至少也要把命令中的空格和最后一个字符删掉,然后重新输入空格和最后一个字符。
以上就是利用 sed 锁定特定行进行文本替换的几种实用技巧。掌握这些基础用法后,日常的文本处理工作会顺畅许多。
