sed 替换匹配开头字符的行
配置文件/etc/config.txt中有一行是
version=xx.xx.xx
每次进行版本发布,需要重新填写这个值,
可以用shell脚本中,加入sed命令来完成新版本号的替换
#首先定义一个新版本号的变量
var="version=6.1.1"
sed -i '/^version=/c'$var'' /etc/config.txt
i :直接修改读取的文件内容,而不是输出到终端。
^表示一行的开头
sed匹配某一行开头,替换整行内容
sed -i '/^cloud_server/ccloud_server_ip = update' name.txt
[root@centos8-38 opt]# cat sed.txt
coud_server xxdfdkjjjj1111 3333
coud_server 3333
coud_server dddd 3333
[root@centos8-38 opt]# coud="cloud_server=1111"
[root@centos8-38 opt]#
[root@centos8-38 opt]# sed '/^coud/c'$coud'' sed.txt
cloud_server=1111
cloud_server=1111
cloud_server=1111
sed 匹配部分替换
[root@centos8-38 opt]# sed 's/dddd/gggg/g' sed.txt
coud_server xxdfdkjjjj1111 3333
coud_server 3333
coud_server gggg 3333
sed 匹配行中部分内容,替换整行
[root@centos8-38 opt]# sed '/.*dddd.*/c'$coud'' sed.txt
coud_server xxdfdkjjjj1111 3333
coud_server 3333
cloud_server=1111
sed 也可以匹配行首或是行尾,中间部分内容后,
再行首或是行尾添加内容。
如下面:
666& 表示添加到行首,&666 表示添加到行尾。
[root@centos8-38 opt]# sed 's/^ccc/666&/g' sed.txt
coud_server xxdfdkjjjj1111 3333
coud_server 3333
coud_server dddd 3333
666cccc 2222
666cccc 111
[root@centos8-38 opt]# sed 's/^.*ddd.*/666&/g' sed.txt
coud_server xxdfdkjjjj1111 3333
coud_server 3333
666coud_server dddd 3333
cccc 2222
cccc 111
1、替换第一次搜索到的内容,命令如下:sed 's/要替换的内容/新的内容/' 要处理的文件如下图,将第一个小写的b替换成了大写的B。
2、在全文中替换所有能匹配的内容,命令如下:sed 's/要替换的内容/新的内容/g' 要处理的文件如下图,将所有的小写的b替换成了大写的B。
3、替换某一行的内容,命令如下:sed '行号c 新的内容' 要处理的文件如下图,将第二行内容替换成了“new test!”。
4、替换多行的内容,命令如下:sed '起始行号,终止行号c 新的内容' 要处理的文件如下图,将第二行到第六行内容替换成了“new test!”。
5、上述这些替换命令都只是将替换的结果显示在屏幕上,如果想替换的结果直接保存到原文中,就只需加上-i参数。
6、sed命令中替换与被替换的部分都允许使用正则表达式。比如,以下命令将所有数字替换成了“好的”。sed 's/[0-9]/好的/g' testFile2.txt 。用以上命令选择一个在最后一行插入就可以了。
sed编辑器是一行一行的处理文件,正在处理的内容存放在模式空间(缓冲区)中,处理完毕后按照选项的规定进行输出或文件的修改。
sed主要用来自动编辑一个或多个文件;简化文件的反复 *** 作,用于非交互编译文件。
可以使用一个简单的数字,或是一个行号范围
注意:p的动作是:打印匹配行。
1. 原始文件:
2. sed的默认动作
(1)sed的默认动作是打印文件中的所有行。
3. 打印特定行
(1)因为sed命令默认打印文件中所有行。所以第三行会被打印两遍。那如何只打印第三行呢?使用【-n】命令,只打印匹配的行。
(2)使用【-n】命令,只打印匹配到的行
(3)打印[n,m]行
(4)打印包含模式的行
(5)打印包含模式和指定行号之间的行
(6)包含模式和包含模式之间的行
(7) {}执行多个命令(command),使用;隔开。=是显示文件行的行号。p是打印匹配行
(8)!取反 *** 作
(9)q命令:第一个模式匹配完成后退出或立即退出,使用该命令打印前5行
(1)使用[]进行正则匹配
(2)其他的正则表达式
(1)打印出以#开头的行,然后用!进行反选,则表示过滤掉以#开头的行,不会过滤掉空格。
(2)匹配以#开头的行,进行取反,则打印出非#开头的行,然后其结果在对空格开头的行进行取反。即 过滤掉以#开头的行和以空格开头的行。 {}表示在定位行执行的命令组。
(3)sed支持对单个文件实现不同的 *** 作,每个 *** 作用-e参数。定位到执行的行后,使用d命令,直接删除匹配到的行。
需要注意的是,对源文件的添加要使用【-i】参数。
s:使用替换模式替换相应模式
(1)在匹配行前面替换字符,使用【s】命令。
(2)在所有行开头替换元素【s】
(3)在所有行的末尾替换元素
(4)指定行,进行替换 *** 作
(5)【&】符号代表的是匹配到的字符。在匹配到字符后,可以使用&代替。
(6)在匹配到行前面添加一行,使用【i】的命令
(7)在匹配行的后面添加一行,使用【a】命令
(8)当添加多行时,使用\n来转义
(9)@代表的是【地址定界符】,一般由三个组成,定界符可以是/,$,#等特殊字符,此命令表示,匹配特定字符的行进行替换。
(10)使用命令【g】修改全文中出现的匹配字符。
(11)若后面接数字之后在接g,表示匹配的行中,第几次出现。就替换,2g表示替换行中第二次出现。
(1)删除以非#号开头的行,即显示以#号开头的行。
(2)删除第一行
(3)删除最后一行
(4)删除指定的行区间
(5)删除包含特定单词的行
本文参考:
sed命令详解
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)