bash grep 判断_Shell grep命令详解:提取符合条件的字符串行

本节讲一下行提取命令 grep。grep 的作用是在文件中提取和匹配符合条件的字符串行。命令格式如下:

[root@localhost ~]# grep [选项] "搜索内容" 文件名

选项:

-A 数字:列出符合条件的行,并列出后续的 n 行;

-B 数字:列出符合条件的行,并列出前面的 n 行;

-c:统计找到的符合条件的字符串的次数;

-i:忽略大小写;

-n:输出行号;

-v:反向査找;

--color=auto:搜索出的关键字用颜色显示;

举几个例子:

[root@localhost ~]# grep "/bin/bash" /etc/passwd

#查找用户信息文件/etc/passwd中有多少可以登录的用户

root:x:0:0:root:/root:/bin/bash

user1:x:500:500::/home/user1:/bin/bash

user2:x:501:501::/home/user2:/bin/bash

grep 是行提取命令,所以只要一行数据中包含"搜索内容",就会列出整行的数据。在这个例子中,会在 /etc/passwd 文件中列出所有包含"/bin/bash"的行,而我们已知只有可登录用户的 Shell 才是"/bin/bash",而伪用户的 Shell 是"/sbin/nologin",所以这条命令会列出当前系统中所有可以登录的用户。

再举几个例子:

[root@localhost ~]# grep -A 3 "root" /etc/passwd

#查找包含"root"的行,并列出后续的3行

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

[root@localhost ~]# grep -n "/bin/bash" /etc/passwd

#查找可以登录的用户,并显示行号

1:root:x:0:0:root:/root:/bin/bash

31:user1:x:500:500::/home/user1:/bin/bash 32:user:x:501:501::/home/user:/bin/bash

[root@localhost ~]# grep -v "/bin/bash" /etc/passwd

#查找不包含"/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

…省略部分输出…

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值