SHELL编程实战:sed

 

目录

1、把/etc/passwd 复制到/root/test.txt,用sed打印所有行

2、打印test.txt的3到10行

3、打印test.txt 中包含’root’的行

4、删除test.txt 的15行以及以后所有行

5、删除test.txt中包含’bash’的行

6、替换test.txt 中’root’为’toor’

7、替换test.txt中’/sbin/nologin’为’/bin/login’

8、删除test.txt中5到10行中所有的数字

9、删除test.txt 中所有特殊字符(除了数字以及大小写字母)

10、在test.txt 20行到末行最前面加’aaa:’

11、删除centos7系统/etc/grub2.cfg文件中所有以空白开头的行行首的空白字符

12、删除/etc/fstab文件中所有以#开头,后面至少跟一个空白字符的行的行首的#和空白字符

13、在centos6系统/root/install.log每一行行首增加#号

14、在/etc/fstab文件中不以#开头的行的行首增加#号

15、处理/etc/sysconfig/network-scripts/路径,使用grep和sed命令取出其目录名和基名

16、利用sed 取出ifconfig命令中本机的IPv4地址

17、统计centos安装光盘中Package目录下的所有rpm文件的以.分隔倒数第二个字段的重复次数

18、删除/etc/grub2.conf文件中所有以空白开头的行行首的空白字符

19、删除/etc/fstab文件中所有以#开头,后面至少跟一个空白字符的行的行首的#和空白字符

20、在/root/install.log每一行行首增加#号

21、在/etc/fstab文件中不以#开头的行的行首增加#号

22、利用sed 取出ifconfig命令中本机的IPv4地址

23、关闭本机SELinux的功能

24、在/etc/hosts配置文件中添加内容

25、显示/etc/passwd文件中以bash结尾的行

26、找出/etc/passwd文件中的三位或四位数

27、找出/etc/grub2.cfg文件中,以至少一个空白字符开头,后面又跟了非空白字符的行

28、找出"netstat -tan”命令的结果中,以‘LISTEN’后跟0或多个空白字符结尾的行

29、找出"fdisk -l“命令的结果中,包含以/dev/后跟sd或hd及一个字母的行

30、找出”ldd /usr/bin/cat“命令的结果中文件路径

31、找出/proc/meminfo文件中,所有以大写或小写s开头的行;至少用三种方式实现

32、显示当前系统上root、centos或spark用户的相关信息

33、echo输出一个绝对路径,使用egrep取出其基名

34、找出ifconfig命令结果中的1-255之间的整数

35、找出系统中其用户名与shell名相同的用户

1、把/etc/passwd 复制到/root/test.txt,用sed打印所有行

cp /etc/passwd /zuoye/day6/test.txt
sed -n '1,$ p' passwd.txt
sed -n 'p' passwd.txt

2、打印test.txt的3到10行

sed -n '3,10 p' passwd.txt

3、打印test.txt 中包含’root’的行

sed -n '/root/ p' passwd.txt 

4、删除test.txt 的15行以及以后所有行

sed '15,$ d' test.txt

5、删除test.txt中包含’bash’的行

sed '/bash/ d' test.txt

6、替换test.txt 中’root’为’toor’

sed -n 's/root/toor/ g p' test.txt	# 查看符合要求的

7、替换test.txt中’/sbin/nologin’为’/bin/login’

sed -n 's/\/sbin\/nologin/\/bin\/login/g p' test.txt	# 需要转义
sed -n 's#/sbin/nologin#/bin/login#g p' test.txt		# 使用 # 实现转义

8、删除test.txt中5到10行中所有的数字

sed -r '5,10 s/^(.*x:)(.*)(:)(.*)(:.*)/\1\3\5/' test.txt
sed -n -r '5,10 s/^(.*x:)(.*)(:)(.*)(:.*)/\1\3\5/ p' test.txt
sed '5,10 s/\<[0-9]*[0-9]\>//' test.txt		删除5-10行的第一个数字

9、删除test.txt 中所有特殊字符(除了数字以及大小写字母)

sed -n "s/[^[:alnum:]]//g p" test.txt

10、在test.txt 20行到末行最前面加’aaa:’

sed '20,$ i\aaa' test.txt
sed '20,$ i aaa' test.txt	# 用空格隔开也可以

11、删除centos7系统/etc/grub2.cfg文件中所有以空白开头的行行首的空白字符

sed -r 's/^[[:space:]]+//' /etc/grub2.cfg

12、删除/etc/fstab文件中所有以#开头,后面至少跟一个空白字符的行的行首的#和空白字符

sed -r "s/^#[[:space:]]+//" /etc/fstab

13、在centos6系统/root/install.log每一行行首增加#号

sed 's/^/# /' /root/install.log

14、在/etc/fstab文件中不以#开头的行的行首增加#号

sed "s/^[^#]/# /" /etc/fstab

15、处理/etc/sysconfig/network-scripts/路径,使用grep和sed命令取出其目录名和基名

echo /etc/sysconfig/network-scripts | sed -r 's#(/.*/).*#\1#'
/etc/sysconfig/
echo /etc/sysconfig/network-scripts | sed -r 's#(/.*/)(.*)#\2#' 
network-scripts

16、利用sed 取出ifconfig命令中本机的IPv4地址

ifconfig ens33 | sed -n '/inet /s#\(.*inet \)\(.*\)\( n.*\)#\2#g p'
ifconfig ens33 | awk -F" " 'NR==2{print $2}'

17、统计centos安装光盘中Package目录下的所有rpm文件的以.分隔倒数第二个字段的重复次数

ls *.rpm | awk -F"." '{print $(NF-1)}' | sort | uniq -c |sort -nr

18、删除/etc/grub2.conf文件中所有以空白开头的行行首的空白字符

sed "/^$/d" /etc/grub.conf

19、删除/etc/fstab文件中所有以#开头,后面至少跟一个空白字符的行的行首的#和空白字符

sed -r "s/^#[[:space:]]+//" /etc/fstab

20、在/root/install.log每一行行首增加#号

sed "s/^/#/" /root/install.log

21、在/etc/fstab文件中不以#开头的行的行首增加#号

sed "s/^/#/" /etc/fstab

22、利用sed 取出ifconfig命令中本机的IPv4地址

ifconfig ens33 | sed -n '/inet /s#\(.*inet \)\(.*\)\(n.*\)#\2#g p'

23、关闭本机SELinux的功能

sed -i 's#SELINUX=enforced#SELINUX=disabled#g' /etc/selinux/config

24、在/etc/hosts配置文件中添加内容

sed -i '内容' /etc/hosts

25、显示/etc/passwd文件中以bash结尾的行

sed -n '/bash$/ p' /etc/passwd

26、找出/etc/passwd文件中的三位或四位数

grep -o "\<[0-9]\{3,4\}\>" /etc/passwd

27、找出/etc/grub2.cfg文件中,以至少一个空白字符开头,后面又跟了非空白字符的行

sed -n '/^[[:space:]]\+[^[:space:]]\+/p' /etc/grub2.cfg
grep "^[[:space:]]\+[^[:space:]]\+" /etc/grub2.cfg

28、找出"netstat -tan”命令的结果中,以‘LISTEN’后跟0或多个空白字符结尾的行

netstat -tan | sed -n '/LISTEN/p'
netstat -tan | grep -E "\<LISTEN[[:space:]]*\>"

29、找出"fdisk -l“命令的结果中,包含以/dev/后跟sd或hd及一个字母的行

fdisk -l | grep -E "/dev/[sh]d[a-z]"

30、找出”ldd /usr/bin/cat“命令的结果中文件路径

ldd /usr/bin/cat | grep -E "/.*/"
ldd /usr/bin/cat | grep -E -o "/.*/"    # 只显示匹配到的

31、找出/proc/meminfo文件中,所有以大写或小写s开头的行;至少用三种方式实现

grep -E "^S.*|^s.*" /proc/meminfo   # 扩展正则 -E 使用 | 分隔,匹配S或s中的一项
grep ^[sS] /proc/meminfo
grep -i ^S /proc/meminfo
sed -n '/^[sS]/p' /proc/meminfo
awk '/^[Ss]/' /proc/meminfo

32、显示当前系统上root、centos或spark用户的相关信息

grep -E -w "^(root|centos|spark)" /etc/passwd

33、echo输出一个绝对路径,使用egrep取出其基名

echo /zuoye/day6/passwd.txt | grep -E -o "/.*/"    # 取出路径名
basename /zuoye/day6/passwd.txt

34、找出ifconfig命令结果中的1-255之间的整数

ifconfig | grep -oE "[1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-5][0-5]"

35、找出系统中其用户名与shell名相同的用户

grep "^\(.*\):.*\1$" /etc/passwd
  • 3
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值