shell三剑客练习题

目录

一.grep部分练习

二.sed部分练习题


一.grep部分练习


1.显示/etc/fstab中以#开头,且后面跟一个或多个空白字符,而后又跟了任意非空白字符的行;

 egrep '^#[[:space:]]+[^[[:space:]]]*' /etc/fstab

2.查找/etc/rc.d/rc.local中包含“以to开始并以to结尾”的字串行;

grep '^to.*to$' /etc/rc.d/rc.local 


3.查找/etc/inittab中含有“以s开头,并以d结尾的单词”模式的行;

grep -w '^s.*d$' /etc/inittab


4.查找ifconfig命令结果中的1-255之间的整数;

ifconfig | egrep -w "[1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-5][0-5]"


5.显示/var/log/secure文件中包含“Failed”或“FAILED”的行;

egrep 'Failed|FAILED' /var/log/secure 


6.在/etc/passwd中取出默认shell为bash的行;

grep 'bash' /etc/passwd


7.以长格式列出/etc/目录下以ns开头、.conf结尾的文件信息;

ls -l /etc/ns*.conf


二.sed部分练习题

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

sed 's/^[[:space:]]*//' conf.txt


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

sed 's/^#[[:space:]]*//' /etc/fstab


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

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


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

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


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

#这里我们使用sed结合awk实现
ifconfig | sed -n "2p" | awk '{print $2}'  #sed取行,awk取列即可得到ip



用ip add取ip:

[root@localhost ~]# ip add
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: ens160: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
    link/ether 00:0c:29:ce:34:5a brd ff:ff:ff:ff:ff:ff
    altname enp3s0
    inet 192.168.145.197/24 brd 192.168.145.255 scope global noprefixroute ens160
       valid_lft forever preferred_lft forever
    inet6 fe80::20c:29ff:fece:345a/64 scope link noprefixroute 
       valid_lft forever preferred_lft forever

取法:

法一:grep结合awk
[root@localhost ~]# ip add | grep ens160 | grep inet | awk '{print $2}' | awk -F/ '{print $1}'
192.168.145.197


法二:sed结合awk
[root@localhost ~]# ip add | sed -n '10p' | awk '{print $2}' | awk -F/ '{print $1}'
192.168.145.197


法三:sed结合awk结合cut
[root@localhost ~]# ip add | sed -n '10p' | awk '{print $2}' | cut -d/ -f 1
192.168.145.197

cut -d/ -f 1
-d 指定分隔符
-f 指定要取出的字段

总结:我们可以使用grep或sed取行,awk取列,awk和cut指定分隔符


6、关闭本机SELinux的功能

sed -i 's/SELINUX=.*/SELINUX=disabled/' /etc/selinux/config

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

sed -i '$a 192.168.1.100   example.com' /etc/hosts


 

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值