8.6正则表达式grep及其他文本处理命令练习

正则表达式grep及其他文本处理命令练习

上课练习 1

1、centos 6找出ifconfig命令结果中本机的IPv4地址

[root@qzx ~]# ifconfig|head -n 2|tail -n 1|tr -s ' [:alpha:]' ':'|cut -d: -f2
10.1.253.75

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

[root@qzx ~]# df | tr -s ' ' '%'|cut -d % -f 5|sort -n |tail -1
52

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

[root@qzx ~]# cat /etc/passwd | sort -n -t : -k 3 | tail -1|cut -d : -f 1,3,7
nfsnobody:65534:/sbin/nologin

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

[root@qzx ~]# stat /tmp
  File: `/tmp'
  Size: 4096          Blocks: 8          IO Block: 4096   directory
Device: 803h/2051d    Inode: 389379      Links: 9
Access: (7777/drwsrwsrwt)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2016-08-05 22:09:27.860003287 +0800
Modify: 2016-08-05 22:09:21.807002986 +0800
Change: 2016-08-05 22:09:21.807002986 +0800
[root@qzx ~]# stat /tmp | tail -n +4|head -n 1 |cut -d / -f1|tr -cd '[0-9]'
7777

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

[root@qzx ~]# netstat -ant | tr -s " " |cut -d " " -f5|tail -n +3 |sort
:::*
:::*
:::*
:::*
:::*
:::*
0.0.0.0:*
0.0.0.0:*
0.0.0.0:*
0.0.0.0:*
0.0.0.0:*
0.0.0.0:*
10.1.250.28:49373

grep命令上课练习

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

[root@qzx ~]# grep -i '^s' /proc/meminfo 
    SwapCached:            0 kB
    SwapTotal:       4194300 kB
    SwapFree:        4194300 kB
    Shmem:              1288 kB
    Slab:             127444 kB
    SReclaimable:      60952 kB
    SUnreclaim:        66492 kB
[root@qzx ~]# grep '^[sS]' /proc/meminfo 
    SwapCached:            0 kB
    SwapTotal:       4194300 kB
    SwapFree:        4194300 kB
    Shmem:              1288 kB
    Slab:             127408 kB
    SReclaimable:      60952 kB
    SUnreclaim:        66456 kB
[root@qzx ~]# grep -E '^(s|S)' /proc/meminfo 
    SwapCached:            0 kB
    SwapTotal:       4194300 kB
    SwapFree:        4194300 kB
    Shmem:              1288 kB
    Slab:             127420 kB
    SReclaimable:      60956 kB
    SUnreclaim:        66464 kB

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

[root@qzx ~]# grep -v '/bin/bash' /etc/passwd
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync

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

[root@qzx ~]# grep '^rpc\>' /etc/passwd
rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin

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

[root@qzx ~]# grep '\<[[:digit:]]\{2,3\}\>' /etc/passwd
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin

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

[root@localhost ~]#  grep '^[[:space:]]\+[^[:space:]]' /etc/grub2.cfg 
  load_env
   set default="${next_entry}"
   set next_entry=

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

[root@localhost ~]# netstat -tan| grep 'LISTEN[[:space:]]*'
tcp        0      0 192.168.122.1:53        0.0.0.0:*               LISTEN     
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN     
tcp        0      0 127.0.0.1:631           0.0.0.0:*               LISTEN

7、添加用户bash、testbash、basher以及nologin(其shell为/sbin/nologin),而后找出/etc/passwd文件中用户名同shell名的行

[root@qzx ~]# grep  '\(^[[:alnum:]]\+\>\).*\1\>$' /etc/passwd
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
bash:x:4329:4330::/home/bash:/bin/bash
nologin:x:4332:4333::/home/nologin:/sbin/nologin

egrep上课练习

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

[root@qzx ~]# egrep '^(root)|(mage)|(wang)' /etc/passwd |cut -d : -f3,7
0:/bin/bash
4333:/bin/bash
4334:/bin/bash

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

[root@qzx ~]# egrep '[[:alpha:]_]+\(\)' /etc/rc.d/init.d/functions 
fstab_decode_str() {
checkpid() {
__readlink() {
__fgrep() {
__kill_pids_term_kill_

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

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

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

[root@qzx ~]#  echo "/etc/re.d/init.d/functions" | egrep -o "/.+/"
/etc/re.d/init.d/

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

[root@qzx ~]# last |egrep '^root.*[[:digit:]\.]{3}[[:digit:]]'|tr -s ' '|cut -d " " -f 3|sort |uniq -c
     11 10.1.250.28
      1 172.18.18.245
      2 172.18.19.122

6、利用扩展正则表达式分别表示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]

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

[root@qzx ~]# ifconfig | egrep -o '([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])'10.1.253.75
10.1.255.255
255.255.0.0
127.0.0.1
255.0.0.0

课下思考题

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

[root@qzx ~]# cat /etc/init.d/functions |tr -cs '[:alpha:]' '\n' |sort|uniq -c|sort -n.
.
.
 73 echo
 75 pid
 77 then
 83 if

正则表达式表示身份证号

egrep -o '([[:digit:]]{17}X)|([[:digit:]]{18})'

测试:

[root@qzx ~]# echo 12345678912345678X |egrep -o '([[:digit:]]{17}X)|([[:digit:]]{18})'
12345678912345678X
[root@qzx ~]# echo 123456789123456780 |egrep -o '([[:digit:]]{17}X)|([[:digit:]]{18})'
123456789123456780

正则表达式表示手机号

1[3,5][0-9]{9}
18[1,2,3,6,7,8,9][0-9]{8}

[root@qzx ~]# echo 18888397111.232565 |egrep -o '1[3,5][0-9]{9}|18[1,2,3,6,7,8,9][0-9]{8}'18888397111
[root@qzx ~]#

正则表达式表示邮箱

 egrep -o '[[:alnum:]_]+@[[:alnum:]]+\.com\>'

测试

[root@qzx ~]# echo 'sdas a, a.sd . .e.asfafgah_dasAAD12@163.com.asda.sfd .sdsee' |egrep '[[:alnum:]_]+@[[:alnum:]]+\.com\>'
sdas a, a.sd . .e.asfafgah_dasAAD12@163.com.asda.sfd .sdsee
[root@qzx ~]# echo 'sdas a, a.sd . .e.asfafgah_dasAAD12@163.com.asda.sfd .sdsee' |egrep -o '[[:alnum:]_]+@[[:alnum:]]+\.com\>'
asfafgah_dasAAD12@163.com

正则表达式表示QQ号

egrep -o [1-9][0-9]{5,10}

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

(0)
qzxqzx
上一篇 2016-08-07
下一篇 2016-08-07

相关推荐

  • 制作kickstart文件和引导镜像

    kickstart制作: (1)通过手动编辑,莫个kickstat模板进行修改:如根目录下的anaconda-ks.cfg (2)通过图形界面制作kickstart文件,可以安装system-config-kickstart, 通过kickstart配置程序打开某个模板,如anaconda-ks.cfg,在图片界面下的修改, 基本配置:默认语音,键盘类型,时…

    2017-11-14
  • PXE自动化安装系统

    PXE自动化安装的流程: 开机自检 > 加载ROM中的bios代码 > 检查设备启动顺序,由于PXE自动安装是基于网卡作引导的,所以,会选择网卡 > 网卡中会有PXE的模块,从dhcp服务器获取ip地址 掩码 网关 dns 重要的是tftp服务器的地址 从tftp服务器需要获取的bootloder的文件名的信息 > 从tftp中加载p…

    Linux干货 2015-08-11
  • 少走冤枉路!带你走过SNMP的那些坑

    SNMP(Simple Network Management Protocol)即简单网络管理协议,是在网络与系统监控领域中,最常使用的一种数据采集技术。尽管这个协议非常简单,但在大规模IT环境监测中,还是经常会碰到各种坑,因此优云开源了一套友好的SNMPAPI,并通过本文简单介绍这套API中的一些特点,希望帮助各位运维同仁提前规避一些问题。 特点[0].&…

    2016-06-22
  • Linux网络管理

                          Linux网络管理   本章内容: 网络概念 OSI七层模型 网络设备 TCP/IP IP地址 配置网络 实现网络组 测试网络 网络工具   网络用户应用程序: WEB浏览器(…

    系统运维 2016-09-12
  • awk学习笔记

        awk是一种模式扫描和处理工具,相对于grep的查找,sed的编辑,它在对数据进行分析生成报表时显得尤为强大。awk通过逐行遍历一个或多个文件的方式,查找模式匹配到的行,而后以指定的分隔符(缺省为空格)进行切片,然后针对切片数据进行处理和分析。事实上,gawk有自己的语言,其本身就相当于一个解释器,允许用户创建…

    Linux干货 2015-08-04
  • Linux概述

    计算机组成概述 计算机组成原理 如上图计算机的组成结构,CPU运行速度远远高于内存,而内存运行速度又远远高于I/O;由于三者运行速度巨大差异,如果系统仅运行一个任务(单任务系统),那么将有大量的CPU空闲时间等待缓慢的I/O及内存的读取。为提高CPU的使用效率,于是便产生了多任务系统系统的需求。 多任务系统 多任务实现的基础,我们知道计算机处理任务主要靠CP…

    Linux干货 2016-12-02