grep命令与正则表达式的应用示例、find命令应用示例

grep命令与正则表达式的应用示例、find命令应用示例

  • 显示当前系统上root、fedora或user1用户的默认shell。

    使用扩展正则表达式,它支持使用A|B表示或者之意。查看用户的默认shell,cat /etc/passwd文件,根据用户名所处位置进行锚定,其最后一个字段即表示该用户的默认shell。实现方式及结果如下:

grep命令与正则表达式的应用示例、find命令应用示例
grep命令与正则表达式的应用示例、find命令应用示例  

  • 找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:hello()。

    这里需要注意的是小括号因为和正则表达式的元字符相冲突,如果直接写()会有歧义,因此需要对小括号进行转义:()。具体结果如下所示:

grep命令与正则表达式的应用示例、find命令应用示例  

  • 使用echo命令输出一个绝对路径,使用grep分别取出其基名。
    取出基名:

grep命令与正则表达式的应用示例、find命令应用示例  

  • 找出ifconfig命令结果中的1-255之间的数字。
    1-255之间的数字,如果按照如下方式分解:
    一位数:1-9
    二位数:10-99
    三位数:100-199,200-255
    使用正则表达式可以这样匹配:

grep命令与正则表达式的应用示例、find命令应用示例  

  • 写一个模式能匹配合理的IP地址。
    要匹配出合理的IP地址,个人理解还需要结合子网掩码来判断,如果是要匹配出ifconfig中合理的ip地址,可以使用如下模式进行匹配:

grep命令与正则表达式的应用示例、find命令应用示例  

  • 写一个模式能匹配出所有的邮件地址。

grep命令与正则表达式的应用示例、find命令应用示例  

  • 查找/var目录下属主为root且属组为mail的所有文件或目录。
    find使用-user选项指定属主,使用-group选项指定属组。结果如下:

grep命令与正则表达式的应用示例、find命令应用示例  

  • 查找当前系统上没有属主或属组的文件,且最近3天内曾被访问过的文件或目录。    
    find使用-nouser选项指定查找没有属主的文件;使用 -nogroup选项查找没有属组的文件;使用 -atime选项指定按文件的最后访问时间查找。结果如下:

grep命令与正则表达式的应用示例、find命令应用示例
grep命令与正则表达式的应用示例、find命令应用示例  

  • 查找/etc目录下所有用户都有写权限的文件。
    find使用-perm选项可以根据文件权限进行查找,常用的有为两种使用方式,一种是-perm /mode,表示任何一类用户中的任何一位权限满足条件即可;一种是-perm -mode,表示每一类用户中的每一位权限满足条件才行。这里要求的是所有用户都有写权限,因此应该使用-perm -mode这种方式。
    结果如下:

grep命令与正则表达式的应用示例、find命令应用示例
也可以使用find /etc -perm -a+w

  • 查找/etc目录下大于1M,且类型为普通文件的所有文件。
    find使用-size选项可以根据文件的大小进行查找,常用的有两种使用方式,一种是-size +#unit (unit表示数字单位,有K,M,G),表示查找大于指定大小的文件;一种是-size -#unit,表示查找小于指定大小的文件。
    结果如下:

grep命令与正则表达式的应用示例、find命令应用示例  

  • 查找/etc/init.d目录下,所有用户都有执行权限,且其它用户有写权限的文件。

grep命令与正则表达式的应用示例、find命令应用示例  

  • 查找/usr目录下不属于root,bin或hadoop的文件。find支持使用操作符-a(相当于and),-o(相当于or),在这里使用-o操作符。!表示取反,类似于-not。

grep命令与正则表达式的应用示例、find命令应用示例  

  • 查找/etc目录下至少有一类用户没有写权限的文件。

grep命令与正则表达式的应用示例、find命令应用示例  

  • 查找/etc目录下最近一周内其内容被修改过且不属于root或hadoop的文件。
    括号要使用转义符,“-7”表示在7天内。
    > [root@localhost etc]# find /etc -mtime -7 ! \( -user root -o -user hadoop \)

原创文章,作者:N24_lantian,如若转载,请注明出处:http://www.178linux.com/61160

(0)
N24_lantianN24_lantian
上一篇 2016-11-28 00:23
下一篇 2016-11-28 09:46

相关推荐

  • 第九周-Shell脚本编程

      1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash nologin=0 login=0 for i in `cut -d : -f 7 /etc/passwd`;do if [ $i = /sbin/n…

    Linux干货 2017-08-23
  • N21沉舟17周作业

    1、结合图形描述LVS的工作原理; NAT模型 NAT模型其实就是通过网络地址转换来实现负载均衡的,它的工作方式几乎跟iptables 中的DNAT一模一样的,NAT模型的工作方式: 1.用户请求VIP(也就是是CIP请求VIP) 2,Director Server 收到用户的请求后,发现源地址为CIP请求的目标地址为VIP,那么Dorector Serve…

    Linux干货 2016-11-14
  • 优云软件数据专家最佳实践:数据挖掘与运维分析

    这份研究报告,作者是优云软件数据专家陈是维,在耗时1年时间制作的一份最佳实践,今天和大家分享下,关于《数据采矿和运维分析》,共同探讨~ 数据挖掘(Data Mining)是从大量数据中提取或“挖掘”知识。 广义数据挖掘:数据挖掘是从存放在数据库、数据仓库或其它信息库中的大量数据挖掘有趣知识的过程。 数据挖掘技术侧重:1)概率与数理统计 2)数据库技术 3)人…

    大数据运维 2016-07-16
  • linux软链接与硬链接的区别

    硬链接:相于当给文件增加了一个新名 在添加链接时会增加链接数,其inode结点数不会增加 支持绝对路径与相对路径 硬链接不能对目录来创建 不能跨分区来创建链接 硬链接链接到文件被删除时,依旧可以通过链接文件来访问被删文件的数据 软链接:可以支持对目录来创建链接 (注,当你用rm -rf 删除目录的时候,目录不会删除,但目录中的内容会被删除,并且会删除源文件)…

    Linux干货 2016-10-02
  • N28第五周

    1、简述rpm与yum命令的常见选项,并举例
    2、自建yum仓库,分别为网络源和本地源
    3、简述at和crontab命令,制定 每周三凌晨三、五点10分执行某个脚本,输出当前时间,时间格式为 2017-12-28 10:00:00
    4、简述sed常用操作命令,并举例

    Linux干货 2018-01-03
  • 网络班N27 第四周作业

    1、 复制/etc/skel目录为/home/tuserl,要求/home/tuserl及其内部文件的属组和其他用户均没有任何访问权限。 [root@ ~]# cp -r /etc/skel /home/tuserl [root@ ~]# chmod -Rv 700 /home/tuserl/ mode of ‘/home/tuserl/’ changed …

    Linux干货 2017-08-19

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-07 23:07

    作业写的很棒,有图有真相