Linux shell grep 练习

使用的文件内容

1:passwd

root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:65534:65534:Kernel Overflow User:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
systemd-coredump:x:999:997:systemd Core Dumper:/:/sbin/nologin
systemd-resolve:x:193:193:systemd Resolver:/:/sbin/nologin
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
polkitd:x:998:996:User for polkitd:/:/sbin/nologin
unbound:x:997:995:Unbound DNS resolver:/etc/unbound:/sbin/nologin
sssd:x:996:993:User for sssd:/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
pesign:x:995:992:Group for the pesign signing daemon:/var/run/pesign:/sbin/nologin
rngd:x:994:991:Random Number Generator Daemon:/var/lib/rngd:/sbin/nologin
jiang:x:1000:1000:jiang:/home/jiang:/bin/bash
apache:x:48:48:Apache:/usr/share/httpd:/sbin/nologin
shell:x:1001:1001::/home/shell:/bin/bash
H_test:x:1002:1002::/home/H_test:/bin/bash

2:test.txt 用于代替所有没有的文件

Carline, ah, how to begin to aloud again case old?
to you to

1、显示/etc/passwd文件中以不区分大小的h开头的行;

1
egrep -i "^h" /etc/passwd
2
grep -ie '^h' /etc/passwd
3
grep -E '^h|^H' /etc/passwd

在这里插入图片描述

2、显示/etc/passwd中以sh结尾的行;

grep -e 'sh$' /etc/passwd

在这里插入图片描述

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

grep -E '^#[[:space:]]+[^[:space:]]+' /etc/fstab

在这里插入图片描述

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

grep -w '^to .* to$' test.txt

在这里插入图片描述

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

grep '\<s[a-Z]*d\>' /etc/inittab

在这里插入图片描述

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

ifconfig | grep -Eo  '\<[1-9]\>|\<[0-9][0-9]\>|\<1[0-9][0-9]\>|\<2[0-5][0-5]\>'

在这里插入图片描述

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

egrep -io 'failed' /var/log/secure 

在这里插入图片描述

8、在/etc/passwd中取出默认shell为bash的行;

在这里插入图片描述

grep '/bin/bash' /etc/passwd

在这里插入图片描述

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

grep '^\<sudo\>.*\.\<conf\>' test.txt

在这里插入图片描述

10、高亮显示passwd文件中冒号,及其两侧的字符;

grep  --color=auto '[[:alnum:]]*:[[:alnum:]]*' passwd

在这里插入图片描述
额,这个可能是错的

sed

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

sed -e 's/^[[:space:]]*//g' grub2.cfg

在这里插入图片描述

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

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

-r 使用扩展正则
![在这里插入图片描述](https://img-blog.csdnimg.cn/31fff61559c9472781a69e63ad44d9aa.png)

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

本机没有 /root/install.log 文件,这里使用 test.txt 文件代替

sed -e 's/^.*$/#&/g' test.txt

在这里插入图片描述

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

sed 's/^[^#].*$/#&/' test.txt

在这里插入图片描述

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

ifconfig | sed -n '2p' | sed -r 's/^[^0-9]+([0-9.]+).*/\1/'

在这里插入图片描述

16、关闭本机SELinux的功能


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


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值