文本及文件查找练习

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

    ~]# cat /etc/passwd | grep "^\(root\|fedora\|user1\)\>" | cut -d: -f1,7
    root:/bin/bash
    fedora:/bin/tcsh
    user1:/bin/bash

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

    ~]# grep  -E  -o  "[_[:alnum:]]+\(\)"  /etc/rc.d/init.d/functions
    checkpid()
    __pids_var_run()
    __pids_pidof()
    daemon()
    killproc()
    pidfileofproc()
    pidofproc()
    status()
    echo_success()
    ……

3、使用echo命令输出一个绝对路径,使用grep取出其基名;
    扩展:取出其路径名
    
    ~]# basename /etc/rc.d/init.d/functions
    functions
    ~]# echo /etc/rc.d/init.d/functions | grep -E -o "[^/]+/?$"
    functions
    
    ~]# dirname /etc/rc.d/init.d/functions
    /etc/rc.d/init.d
    ~]# echo "/etc/rc.d/init.d/functions" | grep -E -o "^/.*[^/]" | grep -E -o "^/.*/" | grep -E -o "^/.*[^/]"
    /etc/rc.d/init.d

4、找出ifconfig命令结果中的1-255之间数字;

    ~]# ifconfig | grep  -E  -o  "\<([1-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\>"

5、挑战题:写一个模式,能匹配合理的IP地址;

    ~]# ifconfig | grep -E -o "([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-
    9]|25[0-5])\.([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])"  

6、挑战题:写一个模式,能匹配出所有的邮件地址;

    正则匹配表达式:^[a-z]([a-z0-9]*[-_]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[\.][a-z]{2,3}([\.][a-z]{2})?$
    
    国际域名格式如下:域名由各国文字的特定字符集、英文字母、数字及“-”(即连字符或减号)任意组合而成, 但开头及结尾均不能含有“-”,“-”不能连续出现 。 域名中字母不分大小写。域名最长可达60个字节(包括后缀.com、.net、.org等)。
    
    说明:
    
        * /内容/i 构成一个不区分大小写的正则表达式;^ 匹配开始;$ 匹配结束。
    
    
    
        * [a-z] E-Mail前缀必需是一个英文字母开头
    
    
    
        * ([a-z0-9]*[-_]?[a-z0-9]+)* 和_a_2、aaa11、_1_a_2匹配,和a1_、aaff_33a_、a__aa不匹配,如果是空字符,也是匹配的,*表示0个或者多个。
    
    
    
        * *表示0个或多个前面的字符.
    
    
    
        * [a-z0-9]* 匹配0个或多个英文字母或者数字;[-_]? 匹配0个或1“-”,因为“-”不能连续出现。
    
    
    
        * [a-z0-9]+ 匹配1个或多个英文字母或者数字,因为“-”不能做为结尾
    
    
    
        * @ 必需有个有@
    
    
    
        * ([a-z0-9]*[-_]?[a-z0-9]+)+ 见上面([a-z0-9]*[-_]?[a-z0-9]+)*解释,但是不能为空,+表示一个或者为多个。
    
    
    
        * [\.] 将特殊字符(.)当成普通字符;[a-z]{2,3} 匹配2个至3个英文字母,一般为com或者net等。
        * ([\.][a-z]{2})? 匹配0个或者1个[\.][a-z]{2}(比如.cn等) 我不知道一般.com.cn最后部份是不是都是两位的,如果不是请修改{2}为{起始字数,结束字数}
    
    来源:http://c.biancheng.net/cpp/html/1432.html
    
    
    grep -E -i "^[a-z]([a-z0-9]*[-_]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[\.][a-z]{2,3}([\.][a-z]{2})?$"
    ~]# echo yaominghe@cptw.com.cn | grep -E -i "^[a-z]([a-z0-9]*[-_]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[\.][a-z]{2,3}([\.][a-z]{2})?$"
    yaominghe@cptw.com.cn
    ~]# echo "111@163.com.cn" | grep -E -i "^[a-z]([a-z0-9]*[-_]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[\.][a-z]{2,3}([\.][a-z]{2})?$"

7、查找/var目录下属主为root,且属组为mail的所有文件或目录;

    ~]# find /var -user root -a -group mail -ls
    1343233114 drwxrwxr-x   2 root mail 4096 Oct  9 14:37 /var/spool/mail
    1370877688 -rw——-   1 root mail 4950 Oct  2 09:32 /var/spool/mail/root
    
8、查找当前系统上没有属主或属组的文件;
     进一步:查找当前系统上没有属主或属组,且最近3天内曾被访问过的文件或目录;

    ~]# find / \( -nouser -o -nogroup \) -a -atime -3

9、查找/etc目录下所有用户都有写权限的文件;

     ~]# find /etc -perm -222 -ls

10、查找/etc目录下大于1M,且类型为普通文件的所有文件;

    ~]# find /etc -size +1M -type f -ls

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

    ~]# find /etc/init.d/ -perm -113 -ls

12、查找/usr目录下不属于root、bin或hadoop的文件;

    ~]# find /usr -not -user root -o -not -user bin -o -not -user hadoop

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

    ~]# find /etc/ -not -perm -222 -ls

14、查找/etc目录下最近一周内其内容被修改过,且不属于root或hadoop的文件;

    ~]# find /etc/ -mtime -7 -a -not \( -user root -a -user hadoop \) -ls
    括号内记得空格符!!!!!

原创文章,作者:N23-苏州-void,如若转载,请注明出处:http://www.178linux.com/54131

(0)
N23-苏州-voidN23-苏州-void
上一篇 2016-10-24
下一篇 2016-10-24

相关推荐

  • GOPS 2016全球运维大会 上海站

    GOPS 2016全球运维大会 • 上海站已经圆满落幕,最新GOPS大会推荐:GOPS2017全球运维大会 • 深圳站 基本信息: GOPS2017全球运维大会 • 深圳站 时间:2017-04-21 08:00:00 至 2017-04-22 18:00:00结束 地点:深圳    会议规模:5000人 会议详情:http://www.…

    系统运维 2016-09-07
  • N25第二周作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。     其常用的有: touch、stat、rm、cp、mv、install touch 命令    命令格式: touch [OPTION]… File… 命令参数: -a&n…

    Linux干货 2016-12-12
  • 磁盘分区管理之磁盘基础知识1

    1、磁盘基础知识 1.1 磁头 磁头是利用气流漂浮在盘片上,并没有接触到盘片,因而可以在各轨间高速来回移动,但如果磁头距离盘片太高,读取的信号就会太弱;太低又会磨到盘片表面,所以盘片表面必须相当光滑平整,任何异物和尘埃均会使得磁头摩擦到表面而造成数据永久性损坏。 硬盘读写磁头为了能在磁盘表面高速来回移动读取数据,则需漂浮在磁盘表面上,但是不能接触,接触就会造…

    Linux干货 2016-09-07
  • N25-第八周

    1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态; 在线的主机使用绿色显示; 不在线的主使用红色显示; #!/bin/bash ipnet=172.16.250. trap ‘trap_action’ INT trap_action() { break return 1 } for ((i=1…

    Linux干货 2017-05-27
  • 文本处理之sed

     sed:是一种行编辑器,它在处理行时会把要处理的行读入模式空间中,处理的是模式空间的内容,一行一行的处理,然后把处理结果显示在屏幕中,不对原文做修改,除非强制重定向。   好处:可同时编辑一个或多个文件,简化了对文件的反复操作。 sed用法:   格式: sed [options ]…'script&#0…

    Linux干货 2016-08-15
  • ​Linux基础知识之文件权限

    实验环境:    Linux系统版本为CentOS6.8_x86_64版本,以root用户和sjsir用户远程用xshell连接系统,进行试验。 文本目录:    1.文件的属性    2.文件权限相关的命令    3.umask 新建文件和目录的默认权限   &nbs…

    Linux干货 2016-08-05

评论列表(1条)

  • 马哥教育
    马哥教育 2016-10-27 13:07

    细节有说明,如果能列出命令执行结果就更好了,加油1