文本处理练习题

文本处理练习:

 

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)
上一篇 2016-08-08 16:15
下一篇 2016-08-08 16:16

相关推荐

  • linux-系统自动化安装

    一、安装程序及配置 CentOS 系统安装 系统启动流程: bootloader–>kernel(initramfs)–>rootfs–>/sbin/init anaconda: 系统安装程序 tui:  基于图形库curses 的文本 窗口 gui :图形窗口 安装程序启动过程 MB…

    Linux干货 2016-09-26
  • LAMP 通过使用脚本的方式安装并部署Discuz

    该脚本有很多辅助的部分,主要是为了让脚本在中途运行失败可以多次运行,所产生的结果是预期的,与第一运行并成功的结果是一样的。初次摄入bash脚本有很多不足,敬请指正。 所需要的软件 apr-1.5.2.tar.bz2 apr-util-1.5.4.tar.bz2 Discuz_X3.2_SC_UTF8.zip freetype-2.5.4.tar.gz htt…

    Linux干货 2016-04-05
  • bash脚本编程之算术运算和文件查找

    算数运算在每个编程语言里面是最基本的功能,在bash里面也是.相对于其他编程语言来说在bash里面不能直接以变量加上变量的形式来表现;比如我们先声明两个变量num1和num2然后再做运算。 num1=2 num2=3 echo "$num1+$num2" 2+3 这里我们显示的结果直接为2+3只是做了变量的替换,而不是做两个变量…

    Linux干货 2016-12-23
  • bash基础特性的应用

    1:使用命令行展开功能来完成以下练习:     (1)、创建/tmp目录下的:a_c, a_d, b_c, b_d ~]# touch  /tmp/{a_{c,d},b_{c,d}}     (2)、创建/tmp/mylinux目录下的:      mkdir…

    Linux干货 2016-11-06
  • ansible学习笔记

    简介:  在日常服务器维护中,从系统安装到程序部署再到发布应用,在大规模的生产环境中,如果需要手动的每台服务器进行安装配置将会给运维人员带来许多繁琐而又重复的工作。这就促使了在每个运维层次中出现了不同的自动化运维工具。 常见的自动化运维工具分类有以下几类:  系统安装运维工具(OS Provisioning):    …

    Linux干货 2015-08-17
  • 管道及重定向

    管道及重定向 1、重定向 在Linux中有时我们在命令的执行过程中,不想将执行结果显示到屏幕上,或者将其结果输出到其他位置 这时就需要重定向来解决这个问题了 首先了解一下Linux中的3种I/O设备: 0:标准输入 1:标准输出 2:标准错误输出 输出重定向:> >> 输入重定向: < << >:将标准输出重定向到文…

    Linux干货 2017-07-28