文本处理练习题

文本处理练习:

 

1.找出本机ip地址

  [root@localhost ~]# ifconfig |head -2 |tail -1 |tr -s ' ' ':' |cut -d: -f3

  10.1.252.221

 

2.查看本机分区最大的利用率

  [root@localhost ~]# df |tr '%' ' ' |tr -s ' ' ':' |cut -d: -f5 |tr '[:alpha:]' ' ' |sort |tail -1

  29

 

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

  [root@localhost ~]# getent passwd |cut -d: -f1,3,7 |sort -t: -k2 -n |tail -1

  nfsnobody:65534:/sbin/nologin

 

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

  [root@localhost ~]# stat /tmp |head -4 |tail -1 |tr -s ' ' ':' |cut -d: -f2 |tr -cd '[:digit:]'

  1777

 

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

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

      5 10.1.252.221

 

 

 

正则表达式练习:

 

1.显示/proc/meminfo文件中以大小写s开头的行

 

[root@localhost home]# grep -i '^s' /proc/meminfo

SwapCached:            0 kB

SwapTotal:       2098172 kB

SwapFree:        2098172 kB

Shmem:              6992 kB

Slab:              70944 kB

SReclaimable:      41568 kB

SUnreclaim:        29376 kB

 

[root@localhost home]# grep '^[Ss]' /proc/meminfo

SwapCached:            0 kB

SwapTotal:       2098172 kB

SwapFree:        2098172 kB

Shmem:              6992 kB

Slab:              70944 kB

SReclaimable:      41568 kB

SUnreclaim:        29376 kB

 

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

 

[root@localhost ~]# grep -v '.*/bin/bash$' /etc/passwd

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

lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

sync:x:5:0:sync:/sbin:/bin/sync

shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown

……

 

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

 

[root@localhost ~]# grep '^rpc\>' /etc/passwd |cut -d: -f7

/sbin/nologin

 

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

 

[root@localhost ~]# grep -w '[[:digit:]]\{2,3\}' /etc/passwd

mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

operator:x:11:0:operator:/root:/sbin/nologin

games:x:12:100:games:/usr/games:/sbin/nologin

ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

nobody:x:99:99:Nobody:/:/sbin/nologin

……

 

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

 

[root@localhost ~]# grep '^[[:space:]]\+.*[^[:space:]][^[:space:]]*' /etc/grub2.cfg

  load_env

   set default="${next_entry}"

   set next_entry=

   save_env next_entry

   set boot_once=true

   set default="${saved_entry}"

  menuentry_id_option="–id"

  menuentry_id_option=""

 

 

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

 

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

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    

tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN    

tcp        0      0 127.0.0.1:6010          0.0.0.0:*               LISTEN

 

 

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

 

[root@localhost ~]# getent passwd |grep '^\<\(.*\)\>.*\b\1\b$'

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:1001:1001::/home/bash:/bin/bash

nologin:x:1004:1004::/home/nologin:/sbin/nologin

 

扩展正则表达式练习:

 

1、显示当前系统root magewang用户的UID和默认shell

 

[root@localhost ~]# getent passwd |grep -E '^\<(root|mage|wang)\>' |cut -d: -f3,7

0:/bin/bash

1005:/bin/bash

1006:/bin/bash

 

2、找出/etc/rc.d/init.d/functions文件中行首为某单词(

括下划线)后面跟一个小括号的行

 

[root@localhost ~]# grep -E '^(_|[[:alpha:]])+\(' /etc/init.d/functions

checkpid() {

__pids_var_run() {

__pids_pidof() {

daemon() {

killproc() {

pidfileofproc() {

pidofproc() {

status() {

 

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

 

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

functions

 

 4、使用egrep取出上面路径的目录名(待确定)

 

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

/etc/rc.d/init.d/

 

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

 

[root@localhost ~]# last |egrep -o '^root\>.*([[:digit:]]\.)[[:digit:]]+' |tr -s ' ' |cut -d" " -f1,3 |sort |uniq -c

     15 root 10.1.250.107

      1 root 192.168.1.104

 

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

 

[0-9]

[1-9][0-9]

1[0-9]{2}

2[0-4][4-9]

25[0-5]

 

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

 

[root@localhost ~]# ifconfig |egrep -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])'

10.1.252.221

255.255.0.0

10.1.255.255

127.0.0.1

255.0.0.0

 

 

 

 

 

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

(0)
JaggerJagger
上一篇 2016-08-08 16:15
下一篇 2016-08-08 16:16

相关推荐

  • HAProxy七种调度方法的简单示意图

    看了三个月,中间因出差和其他事没有看估计也有十几天,刚把35天的视频看完。很多内容都记不住,待第一次看完后再回头看吧。 现在想,对内容进行简单的画图,把基本的体现出来,对记忆和回顾应该有帮助。

    Linux干货 2016-07-26
  • 软链接,硬链接区别

    软硬链接涉及文件系统inode, 区分于inode号,硬链接inode号与链接文件相同,且创建链接不占空间.而软链接占名称字节个空间,且inode号与链接文件不同; 两者查找inode号命令都可查找inode号,命令为ls -i,如需查找本目录要加d; 在创建链接环境上,硬链接只能在同分区创建一个,不能跨分区创建;而软链接可以跨分区创建多个链接文件且可以多个…

    Linux干货 2016-10-20
  • Centos7基于虚拟主机的Lamp配置bbs、Blog、PhpMyAdmin应用程序

    Centos7实现基于虚拟主机的各应用程序搭建: 一、配置三个基于名称的虚拟主机;      (a) discuzX      (b) wordpress      (c) https: phpMyAdmin 1.安装Lamp环境及安装mo…

    Linux干货 2016-10-09
  • 第八周-Shell脚本编程

    1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态; 在线的主机使用绿色显示; 不在线的主使用红色显示; #!/bin/bash for i in {1..254}; do { ip=172.16.250.$i if ping -c 1 -w 1 $ip &> /dev/null …

    Linux干货 2017-08-23
  • 文件通配符是啥?

    文件通配符     包含 ‘?’, ‘*’ 或 ‘[‘ 字符的字符串称为通配符模板(wildcard  pattern).形成路径名(globbing)指一种操作,把通配符模板展开为匹配该串的路径名.匹配定义为:   …

    Linux干货 2017-04-23
  • centos 7.3二进制安装mariadb10.2.8

    1 rpm -qa mariadb* 2 getent passwd mysql useradd -d /app/mysqldb -r -m -s /sbin/nologin mysql 3 tar xvf mariadb-10.2.8-linux-x86_64.tar.gz -C /usr/local/cd /usr/local/ln -s mariadb…

    Linux干货 2017-10-16