sed命令

 如有显示不全,请点击此处转到有道云笔记

知识要点

·sed命令的工作原理
·sed的常用编辑命令
·sed的替换命令
·sed的特殊用法
sed命令的工作原理
sed是一种支持正则表达式的非交互式流编辑器(stream editor)
脚本中修改文本或者文本替换的最佳工具
sed命令的语法
sed的语法命令格式
sed [选项] sed编辑命令 输入文件
shell 命令 | sed [选项] sed编辑命令
sed [选项] -f sed脚本文件 输入文件
sed的常用选项
-n:只显示匹配处理的行(否则会输出所有)
-e:执行多个编辑命令时(一般用;代替)
-i:直接在文件中进行修改,而不是输出到屏幕
-r:支持扩展正则表达式
-f:从脚本文件中读取内容并执行(文件中的编辑命令每行一个,不用;隔开)
sed的常用编辑命令
p:打印匹配行 print
d:删除指定行 delete
a:在匹配行后面追加 append
i:在匹配行前面插入 insert
c:整行替换
r:将文件的内容读入 read
w:将文本写入文件 write
s:字符串替换(匹配正则表达式)substitution
sed命令示例
sed的p命令示例
sed -n ‘/模式/p’ 输入文件
这里的模式可以是正则表达式也可以是精确字符
模式用/括起,扩展正则要加 -r选项
sed -n '/bash/p' /etc/passwd
显示包含bash的行
sed -rn '/^#/!p' /etc/grub.conf
不显示#号开头的
df -h | sed -n '//$/p'
显示以/结尾的行
ifconfig -a | sed -n '/^[[:alpha:]]/p'
显示以字母开头的行
sed的p命令示例
sed -n ‘行号1,行号2p’ 输入文件
sed -n 2,3p /etc/passwd 显示2到3行
sed -n ‘10p’ /etc/passwd 显示第10行
sed -n ‘$p’ /etc/passwd 显示最后1行
sed -n '2,+2p' /etc/passwd 显示234行
sed -n ‘3,100!p’ /etc/passwd 显示1到2行
sed的d命令示例
删除操作可以根据行号和模式匹配进行操作
sed '3,5d' /etc/fstab
删除3到5行
sed '/2/d' /etc/fstab
删除包含数字2的行
sed '/ext3/!d' /etc/fstab
除了包含ext3的行都删除
sed -r '/^$|^#/d' /etc/inittab
删除空行和注释
sed -e '/^$/d' -e '/^#/d' /etc/vsftpd/vsftpd.conf
sed '/^$/d ; /^#/d' /etc/vsftpd/vsftpd.conf
sed的a命令示例
追加操作可以根据行号和模式匹配进行操作
sed '1a 1111111111111111' /etc/fstab
在第一行面追加后面的字符串,追加到行下面
sed '/boot/a 1111111111111' /etc/fstab
在包含boot的行下面追加后面的字符串
sed的i命令示例
插入操作可以根据行号和模式匹配进行操作
sed '$i 1111111111111111' /etc/fstab
在最后一行前面插入后面的字符串
sed '/defaults/i 1111111111111' /etc/fstab
在包含defaults的行前面插入后面的字符串
sed的c命令示例
更改整行操作可以根据行号和模式匹配进行操作
sed ‘/id:/c id:5:initdefault:' /etc/inittab
将id:所在的行整行替换成后面的字符串
sed '3c ONBOOT=no' ifcfg-eth0
将第三行改成后面的字符串
sed的r命令示例
读入操作可以根据行号和模式匹配进行操作
sed ‘$r /etc/hosts' /etc/fstab
在fstab文件的末尾后面读入hosts文件的内容
df -h | sed '/dev/sda1/r /etc/mtab‘
在/dev/sda1后面读入mtab文件的内容
sed的w命令示例
写入文件操作可以根据行号和模式匹配进行操作
sed '1w abc.txt' /etc/passwd
将文件的第一行写入abc.txt
sed '/^#/!w abc.txt' /etc/inittab
将所有不是#开头的行都写入abc.txt
sed -r '/^#|^$/!w abc.txt' /etc/vsftpd/vsftpd.conf
将配置文件中除了空行和注释都写入abc.txt
sed的s命令语法格式
sed -n [行号或模式]s/查找内容/替换内容/[替换标记] 文件
替换操作可以根据行号和模式匹配进行操作
替换标记有四种
数字:替换每行的第几个
g:全局替换,否则只替换第一个字符串。例如ng从第n个开始替换
p:显示被执行替换操作的行和-n合用
w:将执行替换操作的行输出到指定文件
sed的s命令
sed -n 's/root/ROOT/2p' /etc/passwd
将文件中每行的第2个root替换为ROOT
sed '/^id/s/:3:/:6:/' /etc/inittab
将文件中找到以id开头的行中的:3:替换成:5:
sed '/^local_enable/s/YES/NO/' vsftpd.conf
禁止本地用户登陆
sed 's/:/ /g' /etc/passwd
将文件中的:号替换为换行符
sed 's/bash/nologin/ ; s/sbin/bin/' /etc/passwd
将文件中bash替换成nologin,同时将sbin替换成bin
sed的s命令
sed -n '2,10s/^/#/p' /etc/passwd
在2到10行前面加上注释
sed -n ‘s/$/?/p' /etc/passwd
在每行末尾加上?
sed的s命令可以使用任意分隔符作为定界符
sed -n '/^hello/s//bin/bash//sbin/nologin/p' /etc/passwd
sed -n '/^hello/s|/bin/bash|/sbin/nologin|p' /etc/passwd
sed -n '/^hello/s:/bin/bash:/sbin/nologin:p' /etc/passwd
注意:-i选项是直接修改文件,小心使用
sed命令特殊用法
sed的命令中包含变量
sed的命令中有多次操作
sed的命令中取反操作
sed的命令中&的用法
&用于表示替换命令中的匹配模式
sed -rn 's/<[0-9]{3}>/&0/gp' /etc/passwd
将所有三位数字后面加个0
sed的s命令中支持
sed -n 's/^xixi/ 1111111111111111/p' /etc/passwd
sed -n 's/^xixi/ 1111111111111111/p' /etc/passwd
sed 's/^abrt.*/& /' passwd
sed的命令中标签的用法
标签:sed使用圆括号定义替换模式中的部分字符
标签可以方便在后面引用,每行指令最多使用9个标签
sed -r 's/(^[[:alnum:]]+)(.*)/1/' /etc/passwd
显示文件的第一列
sed -r 's/(^[[:alnum:]]+)(.*)/2/' /etc/passwd
删除文件的第一列
echo aaa bbb ccc | sed -r 's/([a-z]+) ([a-z]+) ([a-z]+)/3 2 1/‘
ccc bbb aaa
sed命令实验案例1
要求去掉每行前面的空格和数字
cat -n /etc/passwd > test
要求将文件中的网络路径换成本地路径
/var/www/html/
sed命令实验案例2
sed去掉接在命令行后面的注释
sed取出/etc/passwd文件的第一列
sed将PATH环境变量中的冒号换成换行
sed将PATH环境变量斜杠/换成斜杠
sed修改SELINUX配置文件从开启变成禁用
去掉/etc/passwd文件中第二个字段的x
只显示ifconfig的ip地址
sed命令实验案例3
编写脚本使用sed命令修改IP地址和子网掩码,要求如下:
1、输入当前IP
2、输入新IP和子网掩码
3、校验IP和子网掩码的合法性
4、立即生效和永久生效
5、修改失败要恢复原IP
sed命令实验案例4
编写脚本修改主机名,要求如下:
1、输入新的主机名(read 或者参数)
2、立即生效和永久生效
3、修改失败,要恢复原来的主机名
临时修改主机名
hostname 主机名
永久修改主机名:
修改文件vim /etc/sysconfig/network
修改HOSTNAME行
NETWORKING=yes
HOSTNAME=localhost.localdomain
修改主机名后,还需要修改域名解析文件
如果该文件中有旧的主机名,也需要改为新的主机名
域名解析文件
/etc/hosts
修改解析vim /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
添加新的
原文地址:https://www.cnblogs.com/qluzzh/p/10322539.html