`sed`命令替换文本中的单词

简介: `sed`命令替换文本中的单词

sed(流编辑器)是一个强大的文本处理工具,在Unix和类Unix系统中广泛用于执行各种文本转换,其中包括查找并替换文本中的单词或字符串。以下是使用sed命令替换文本中的单词的基本语法:

sed 's/原始单词/新单词/选项' 输入文件
  • s 是替换命令标志,表示接下来会定义一个替换操作。
  • /原始单词/ 是你要查找并替换的单词或正则表达式。
  • /新单词/ 是你要用来替换原始单词的新内容。
  • 选项 可以是:
    • g 表示全局替换,即在同一行内所有出现的“原始单词”都会被替换。
    • 如果不指定g,默认情况下仅替换每行中第一个匹配到的“原始单词”。

例如,假设你有一个文本文件data.txt,你想将文件中所有的“oldword”替换为“newword”,可以这样操作:

sed 's/oldword/newword/g' data.txt

如果想直接在原文件上修改,可以加上 -i 参数:

sed -i 's/oldword/newword/g' data.txt

这里需要注意,sed中的正则表达式特殊字符需要转义,比如如果原始单词或新单词中包含 / 或者 & 等特殊字符,需要在其前面加上 \ 进行转义。

另外,sed还支持地址范围选择,你可以指定只在某些行上执行替换操作,例如:

# 只替换包含 "lineStart" 的行中的 "oldword"
sed '/lineStart/s/oldword/newword/g' data.txt
目录
相关文章
|
6月前
|
Unix Linux
`grep`命令进行文本搜索并忽略大小写
`grep`命令进行文本搜索并忽略大小写
377 2
|
6月前
|
Java
java读取txt文件,使用逗号,分号,空格,回车将文件内容分割成一个一个的词组,找出所有重复的词组
java读取txt文件,使用逗号,分号,空格,回车将文件内容分割成一个一个的词组,找出所有重复的词组
142 38
|
12月前
|
Perl
解决sed替换文本,里面含有“/“、“#”等特殊字符的问题
解决sed替换文本,里面含有“/“、“#”等特殊字符的问题
993 0
|
Ubuntu Linux Perl
如何使用 sed 替换文件中的字符串?
如何使用 sed 替换文件中的字符串?
206 0
|
机器学习/深度学习 Java Shell
文本三剑客之awk命令(上)
1 awk概述 awk的工作原理: 逐行读取文本,默认以空格或tab键为分隔符进行分隔,将分隔所得的各个字段保存到内建变量中,并按模式或者条件执行编辑命令。 awk倾向于将一行分成多个"字段"然后再进行处理。 awk信息的读入也是逐行读取的,执行结果可以通过print的功能将字段数据打印显示。 使用awk命令的过程中,可以使用逻辑操作符"&&"表示"与"、"|"表示"或"、"!"表示"非",还可以进行简单的数学运算,如+、-、*、/、%、^分别表示加、减、乘、除、取余和乘方。
164 0
|
数据安全/隐私保护 Perl
文本三剑客之awk命令(下)
1 awk概述 awk的工作原理: 逐行读取文本,默认以空格或tab键为分隔符进行分隔,将分隔所得的各个字段保存到内建变量中,并按模式或者条件执行编辑命令。 awk倾向于将一行分成多个"字段"然后再进行处理。 awk信息的读入也是逐行读取的,执行结果可以通过print的功能将字段数据打印显示。 使用awk命令的过程中,可以使用逻辑操作符"&&"表示"与"、"|"表示"或"、"!"表示"非",还可以进行简单的数学运算,如+、-、*、/、%、^分别表示加、减、乘、除、取余和乘方。
139 0
|
Linux Perl
LINUX使用sed,字串中包含特殊字符怎么办?
LINUX使用sed,字串中包含特殊字符怎么办?
151 0
|
Shell Perl
SHELL中使用sed替换文本
SHELL中使用sed替换文本
120 0
|
Perl
Sed 删除包含某些字符串的行
sed -i '/关键字符/d' 文件名
2063 0
|
PHP Perl
sed 多行替换,多行模式处理字符串;一次替换
作者:凨 例: 需求:sed 替换多行(2到6行)替换为空,且返回系统配置信息 <?php /**CustomConfigurationStart*/ $c=require APP_PATH.'Common/Conf/config-custom.php'; /*COOKIES,SESSION域*/ $domain=preg_replace('/(.*\.|.*\/\/)?(
3410 0