问题描述
我想替换文件中的特定字符。例如,我有一个 20 行的文件,我想替换第 5 行和第 12 列上的字母 a。
例子:
我在第 5 行的内容 Hello World!
我想用 !
?
这不能通过搜索和替换方法来完成,因为文件中的实际文本或多或少是随机的或经常变化的。我需要在第 5 行第 12 列指定未知字符,然后替换
解决方法
编辑 - 比我的答案更好:
来自@Cyrus:
sed -E '5 s/(.{11})./\1?/' your_file
来自@potong:
sed '5s/./?/12' your_file
我的原始答案(只是为了与更清洁的方法形成对比)
这样做:
sed '5 s/\(.\{11\}\).\(.*\)/\1?\2/' your_file
它的工作方式如下:
- 在第 5 行,执行替换
- 我记得上面使用
\(
和\)
之间的内容 - 第一个记住的部分匹配任意类型的 11 个字符
.\{11\}
- 然后匹配任何类型的单个字符(在您的情况下,这将是 '!')
- 第二个记住的部分匹配单个字符后的所有内容
\{.*\}
- 然后我们放回记住的内容
\1
和\2
- 但是我们用问号替换了单个匹配的字符
一旦您确认它符合您的要求,您就可以添加 -i
来执行
就地替换:
sed -i '5 s/\(.\{11\}\).\(.*\)/\1?\2/' your_file
如果我们使用扩展表达式标志(-E
),我们不必逃避那么多
东西:
sed -E '5 s/(.{11}).(.*)/\1?\2/' your_file