正则表达式相关运用作业

1、取本机ip地址

    [root@ali ~]# ifconfig |egrep 'Bcast' |tr -s ' ' '\n' |head -n3 |tail -n1 |cut -d: -f2

blob.png

2、取各分区利用率的数值

    [root@ali ~]# df |egrep '^/dev/sd'

blob.png

3、统计/etc/init.d/functions 文件中每个单词出现的次数,并按频率从高到低

    [root@ali ~]# cat /etc/rc.d/init.d/functions |tr -cs '[:alpha:]' '\n' |sort |uniq -c |sort -nr

blob.png4、/etc/rc.d/init.d/functions或/etc/rc.d/init.d/functions/"  取目录名

    [root@ali ~]# echo "/etc/rc.d/init.d/functions/" |grep -o "[/]\?.*[/]"

blob.png

5、正则表达式表示身份证号

    '[0-9]{15,18}' 134.txt

6、正则表达式表示手机号

    ^[1][0-9][0-9]{9}$

7、正则表达式表示邮箱

    ^[0-9]{9}@[[:alpha:]].*[[:alpha:]]$

8、正则表达式表示QQ号

    [0-9]{9}

9、显示/proc/meminfo文件中以大小s开头的行; (要求:使用两种方式)

    [root@ali ~]# cat /proc/meminfo |grep -i '^[s]'

blob.png

    [root@ali ~]# cat /proc/meminfo |grep  '^[s|S]'

blob.png

10、显示/etc/passwd文件中不以/bin/bash结尾的行

    [root@ali ~]# cat /etc/passwd |grep -v '/bin/bash'

blob.png

11、显示用户rpc默认的shell程序

    [root@ali ~]# cat /etc/passwd |egrep '\<rpc\>' |cut -d: -f7

blob.png

12、找出/etc/passwd中的两位或三位数

    [root@ali ~]# cat /etc/passwd |grep '\<[1-9][0-9][0-9]\?\>'

blob.png

    [root@ali ~]# cat /etc/passwd |grep '\<[0-9]\{2,3\}\>'

blob.png

13、显示/etc/grub2.cfg文件中,至少以一个空白字符开头的且后面存非空白字符的行

    [root@ali ~]# grep '^[[:space:]]*[^[:space:]]' /etc/rc.d/init.d/functions

14、 找出“netstat -tan”命令的结果中以‘LISTEN’后跟任意多个空白字符结尾的行

    [root@ali ~]# netstat -tan |grep 'LISTEN[[:space:]]*$'

blob.png

15、添加用户bash、 testbash、 basher以及nologin(其shell为/sbin/nologin),而后找

  出/etc/passwd文件中用户名同shell名的行    

    [root@ali ~]# cat /etc/passwd |grep '^\(.*\).*/\1$'

    [root@ali ~]# grep '^\(.*\).*/\1$' /etc/passwd

blob.png

17、查出分区空间使用率的最大百分比值

    [root@ali ~]# df |grep '/dev/sda' |grep '\<[0-9]*%'

blob.png

18、查出用户UID最大值的用户名、 UID及shell类型

    [root@ali ~]# getent passwd |sort -nt: -k3 |cut -d: -f1,3,7 |tail -n1

blob.png

19、查出/tmp的权限,以数字方式显示

    [root@ali ~]# stat /tmp/ |cut -d: -f2 |head -n4 |tr -d '(' |cut -d/ -f1 |tail -n1

blob.png

    [root@ali ~]# stat /tmp/ |head -n4 |tail -n1 |tr ' ' '\n' |head -n2 |tr -cd '[:digit:]'

blob.png

    [root@ali ~]# stat -c %a /tmp/

blob.png

20、统计当前连接本机的每个远程主机IP的连接数,并按从大到小排序

    [root@ali ~]# netstat -nt |grep 'tcp' |tr -s ' ' '|' |cut -d'|' -f4 |uniq -c |sort -n

blob.png

21、 显示三个用户root、 mage、 wang的UID和默认shell

    [root@ali ~]# egrep '^\<root|mage|wang\>' /etc/passwd |cut -d: -f1,3,7

blob.png

22、找出/etc/rc.d/init.d/functions文件中行首为某单词(包括下划线)后面跟一个小括号的行

    [root@ali ~]# cat /etc/rc.d/init.d/functions |egrep '^[[:alpha:]_]+\(\)'

blob.png

23、使用egrep取出/etc/rc.d/init.d/functions中其基名

    [root@ali ~]# echo '/etc/rc.d/init.d/functions' |egrep -o '[^/]+/?$'

blob.png

24、使用egrep取出上面路径的目录名

    [root@ali ~]# echo '/etc/rc.d/init.d/functions' |egrep -o '(/.*/)'

blob.png

 25、统计以root身份登录的每个远程主机IP地址的登录次数

    [root@ali ~]# last |egrep "^root\>.*([[:digit:]]{1,3}\.){3}[[:digit:]]{1,3}" |tr -s ' ' ':' |cut -d: -f3 |sort |uniq -c

    28 10.1.250.14

    1 172.18.19.209

blob.png

 26、利用扩展正则表达式分别表示0-9、 10-99、 100-199、200-249、 250-255

    '(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])'

27、显示ifconfig命令结果中所有IPv4地址

    [root@ali ~]# ifconfig |grep -E -o  '(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]

    {2}|2[0-4][0-9]|25[0-5])'

blob.png

原创文章,作者:M20-1马星,如若转载,请注明出处:http://www.178linux.com/30236

(0)
M20-1马星M20-1马星
上一篇 2016-08-08
下一篇 2016-08-08

相关推荐

  • 安全与加密、申请CA证书

    本章内容 v  1、安全机制  2、对称加密  3、不对称加密 4、散列算法  5、PKI 和CA v 在互联网数据传输的过程的,数据的安全私密性是及其重要的,所以就有数据的加密和解密的过程。 数据加密,是一门历史悠久的技术,指通过加密算法和加密密钥将明文转变为密文,而解密则是通过解密算法和解密密钥将密文恢复为明文。它…

    Linux干货 2016-12-04
  • IO重定向和管理及管道

    IO重定向   通常对程序来讲,输入输出数据可以是键盘、鼠标、显示器等;IO重定向就是将原来系统命令的默认执行方式进行改变,比如说简单的我不想看到在显示器输出而是希望输入到某以文件中的可以通过Linux重定向进行这项工作。  IO重定向和FD(File Descriptor)有关。      标准输入(std…

    Linux干货 2016-08-05
  • 2016-08-12作业

    1、查找/var 目录下属主为root ,且属组为mail 的所有文件 [root@localhost bin]# find /var -user root -group mail /var/spool/mail /var/spool/mail/root   2、查找/var 目录下不属于root 、lp 、gdm 的所有文件 find /var …

    Linux干货 2016-08-15
  • Linux Service and Security(Part 2)

    接PART 1 4、SSH端口转发:SSH会自动加密和解密所有SSH客户端与服务端之间的网络数据。但是,SSH还能够将其它TCP端口的网络数据通过SSH链接来转发,并且自动提供了相应的加密及解密服务,这一过程也被叫做“隧道(tunneling)”。telnet,SMTP,LDAP这些TCP应用均能够从中得益,避免了用户名、密码以及隐私信息的明文传输。同时,如…

    Linux干货 2016-10-09
  • 文本处理工具Sed

    sed的基本用法和高级用法

    2018-04-15
  • linux计划任务

    linux计划任务、周期性任务执行 未来的某时间点执行一次某任务:at,batch 周期性运行某任务:crontab 执行结果: 会通过邮件发送给用户, 存放在/var/spool/mail/UserName ~]# ss -tnl 或者 ~]# netstat -tnlp  查看是否有25号端口打开,来判断本机的邮件服务是否正常打开 本地电子邮件…

    Linux干货 2016-09-19