通配符及管道命令

2018-05-29  本文已影响0人  Hye_Lau

一.常用通配符

globbing:文件名通配(整体文件名匹配,而非部分)
匹配模式:元字符

*:匹配任意长度的任意字符

常用格式

pa*,*pa*,*pa,*p*a*

实例

// 找出/etc/下面以cron开头的文件名
[root@localhost ~]# ll -d /etc/cron*
drwxr-xr-x. 2 root root 4096 7月   2 2017 /etc/cron.d
drwxr-xr-x. 2 root root 4096 7月   2 2017 /etc/cron.daily
-rw-r--r--. 1 root root    0 7月  19 2011 /etc/cron.deny
drwxr-xr-x. 2 root root 4096 7月   2 2017 /etc/cron.hourly
drwxr-xr-x. 2 root root 4096 7月   2 2017 /etc/cron.monthly
-rw-r--r--. 1 root root  457 9月  27 2011 /etc/crontab
drwxr-xr-x. 2 root root 4096 9月  27 2011 /etc/cron.weekly

?:匹配任意单个字符

常用格式

pa?,??pa,p?a?

实例

// 找出/etc/下面文件名刚好是五个字母的文件名
[root@localhost ~]# ll -d /etc/?????    <==五个?对应五个字母
drwxr-x---. 2 root root 4096 7月   2 2017 /etc/audit
drwxr-xr-x. 4 root root 4096 7月   2 2017 /etc/avahi
drwxr-xr-x. 2 root root 4096 5月  11 01:08 /etc/blkid
drwxr-xr-x. 4 root root 4096 7月   2 2017 /etc/fonts
-rw-r--r--. 1 root root  899 7月   2 2017 /etc/fstab
......
-rw-r--r--. 1 root root 1962 2月  17 2012 /etc/vimrc

[ ]:匹配指定范围内的任意字符

几种特殊格式:

实例

// 找出/etc/下面文件名含有数字的文件名
[root@localhost ~]# ll -d /etc/*[0-9]*
drwxr-xr-x. 4 root root 4096 7月   2 2017 /etc/dbus-1
-rw-r--r--. 1 root root 5139 4月  17 2012 /etc/DIR_COLORS.256color
drwxr-xr-x. 3 root root 4096 7月   2 2017 /etc/gnome-vfs-2.0
drwxr-xr-x. 3 root root 4096 7月   2 2017 /etc/gtk-2.0
drwxr-xr-x. 2 root root 4096 7月   2 2017 /etc/iproute2
-rw-r--r--. 1 root root  449 5月   2 2012 /etc/krb5.conf
-rw-r--r--. 1 root root  801 9月   8 2009 /etc/mke2fs.conf
drwxr-xr-x. 5 root root 4096 7月   2 2017 /etc/polkit-1

[^]:匹配指定范围外的任意单个字符

实例

// 找出/etc/下面文件名开头非为大写字母的文件名
[root@localhost ~]# ll -d /etc/[^A-Z]*
drwxr-xr-x. 3 root root  4096 7月   2 2017 /etc/abrt
drwxr-xr-x. 4 root root  4096 7月   2 2017 /etc/acpi
-rw-r--r--. 1 root root    44 4月  23 22:53 /etc/adjtime
-rw-r--r--. 1 root root  1512 1月  12 2010 /etc/aliases
-rw-r--r--. 1 root root 12288 7月   2 2017 /etc/aliases.db
drwxr-xr-x. 2 root root  4096 7月   2 2017 /etc/alsa
drwxr-xr-x. 2 root root  4096 7月   2 2017 /etc/alternatives
[root@localhost ~]# ls -d /etc/l?[[:lower:]]
/etc/lvm
ls -d /etc/[0-9]*[^0-9]
ls -d /etc/[^a-z][a-z]*
[root@localhost ~]# cp -r /etc/m*[^0-9] /tmp/test
[root@localhost ~]# cd /tmp/test
[root@localhost test]# ls
magic    mail.rc    man.config  mime.types   modprobe.d  mtab
mailcap  makedev.d  maven       mke2fs.conf  motd        my.cnf
cp -r /user/share/man/man*[0-9] /tmp/man/
cp -r /etc/[mnrp]*.conf /tmp/conf.d/

注意:4/5/6题需要自己先创建目录

二.文本处理工具

1.cut命令

命令格式

cut OPTION...[FILE]...

常用选项

-d:后面跟分隔符,与-f一起使用;
-f:指明需要取出的字段
    #:第#个字段
    #,#,#:离散的字段,如1,2,3
    #-#:连续的多个字段,如1-6
   混合使用:1-3,7,9,11-15

实例

[root@localhost ~]# echo $PATH
/usr/lib/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
//以:作为分隔符,将上述字段分成了8个字段
[root@localhost ~]# echo $PATH | cut -d ':' -f 3,5
/usr/local/bin:/bin

//用last在显示的登录者的信息中仅留下用户大名
[root@localhost ~]# last
mageia   pts/1        192.168.0.8      Wed May 23 05:02 - 05:02  (00:00)    
root     pts/0        192.168.0.8      Thu May 17 23:23   still logged in   
logstash pts/1        192.168.0.8      Wed May 16 00:12 - 16:56  (16:43)    
......
wtmp begins Sun Jul  2 04:21:54 2017
[root@localhost ~]# last | cut -d ' ' -f 1
mageia
root
logstash
......
wtmp

2.wc命令

常用格式

cut OPTION...[FILE]...

常用选项

-l:仅列出行;
-w:仅列出多少字(英文单字);
-c:统计字符个数

实例

[root@localhost ~]# cat /etc/man.config | wc
    152     765    4940
[root@localhost ~]# cat /etc/man.config | wc -l
152
[root@localhost ~]# cat /etc/man.config | wc -w
765
[root@localhost ~]# cat /etc/man.config | wc -c
4940

3.sort命令

命令格式

sort OPTION...[FILE]...

常用选项

-f:忽略大小写
-r:逆序
-t:字段分隔符,默认是用[Tab]键来分隔;
-k #:以指定字段为标准排序;
-n:使用“纯数字”进行排序
-u:相同的数据中,进出线一行代表

实例

//以“第一个”数据来排序,以“文字”类型来排序
[root@localhost ~]# cat /etc/passwd | sort
abrt:x:173:173::/etc/abrt:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
basher:x:502:502::/home/basher:/bin/bash
bash:x:501:501::/home/bash:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
distro:x:4017:2018::/home/distro:/bin/bash
//以“:”为分隔符,以第三字段内容进行排序,依旧为“文字”排序
[root@localhost ~]# cat /etc/passwd | sort -t ':' -k 3
root:x:0:0:root:/root:/bin/bash
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
mageia:x:1100:1100::/home/linux:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
bin:x:1:1:bin:/bin:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin

//以数字排序
[root@localhost ~]# cat /etc/passwd | sort -t ':' -k 3 -n
root:x:0:0:root:/root:/bin/bash
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

4.uniq命令

命令格式

uniq OPTION...[INPUT[output]]

常用选项

-c:显示每行重复的次数
-d:仅显示重复的行
-u:仅显示不重复的行

实例

//使用last账号列出,仅取出账号列,进行排序后仅取出一位
[root@localhost ~]# last | cut -d ' ' -f1 | sort | uniq

logstash
mageia
reboot
root
wtmp

//上例的基础上,统计出每个账户的登录次数
[root@localhost ~]# last | cut -d ' ' -f1 | sort | uniq -c
      1 
      1 logstash
      1 mageia
     10 reboot
     22 root
      1 wtmp
//reboot登录10次,root登录22次,其余为1次

练习

root@localhost ~]# who
root     tty1         2018-05-12 23:23
root     pts/0        2018-05-17 23:23 (192.168.0.8)
[root@localhost ~]# who | cut -d ' ' -f 1
root
root
[root@localhost ~]# who | cut -d ' ' -f 1 | sort -u
root
[root@localhost ~]# last| head -1
mageia   pts/1        192.168.0.8      Wed May 23 05:02 - 05:02  (00:00) 
[root@localhost ~]# cat /etc/passwd | cut -d ':' -f7 | uniq -c
      1 /bin/bash
      4 /sbin/nologin
      1 /bin/sync
      1 /sbin/shutdown
      1 /sbin/halt
     21 /sbin/nologin
      3 /bin/bash
      1 /bin/sh
      6 /bin/bash
      1 /bin/tcsh
[root@localhost ~]# cat /etc/passwd | cut -d ':' -f7 | uniq -c | sort -n | tail -1
     21 /sbin/nologin
[root@localhost ~]# cat /etc/passwd |sort -t ':' -k3 -n | tail -n10 | tr 'a-z' 'A-Z' > /tmp/maxuser.txt
[root@localhost ~]# cat /tmp/maxuser.txt 
BASHER:X:502:502::/HOME/BASHER:/BIN/BASH
MAGEIA:X:1100:1100::/HOME/LINUX:/BIN/BASH
SLACKWARE:X:2002:2018::/HOME/SLACKWARE:/BIN/TCSH
USER_U:X:4000:5002::/HOME/USER_U:/BIN/BASH
TEST:X:4006:4006:UNIQE:/HOME/TEST:/BIN/SH
HBASE:X:4011:4011::/HOME/HBASE:/BIN/BASH
LOGSTASH:X:4015:4015::/HOME/LOGSTASH:/BIN/BASH
USER_G:X:4016:5002::/HOME/USER_G:/BIN/BASH
DISTRO:X:4017:2018::/HOME/DISTRO:/BIN/BASH
NFSNOBODY:X:65534:65534:ANONYMOUS NFS USER:/VAR/LIB/NFS:/SBIN/NOLOGIN
[root@localhost ~]# ifconfig 
eth0      Link encap:Ethernet  HWaddr 00:0C:29:48:5F:02  
          inet addr:192.168.0.10  Bcast:192.168.0.255  Mask:255.255.255.0
          inet6 addr: fe80::20c:29ff:fe48:5f02/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:1574963 errors:3 dropped:3 overruns:0 frame:0
          TX packets:76439 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:125478876 (119.6 MiB)  TX bytes:6134879 (5.8 MiB)
          Interrupt:19 Base address:0x2000 

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:194 errors:0 dropped:0 overruns:0 frame:0
          TX packets:194 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:16230 (15.8 KiB)  TX bytes:16230 (15.8 KiB)
[root@localhost ~]# ifconfig | head -2 | tail -1 | cut -d ':' -f2
192.168.0.10  Bcast
[root@localhost ~]# ifconfig | head -2 | tail -1 | cut -d ':' -f2 |cut -d ' ' -f1
192.168.0.10
[root@localhost ~]# find /etc -name "*.conf" | tr 'a-z' 'A-Z' > /tmp/etc.conf
[root@localhost ~]# cat /tmp/etc.conf 
/ETC/DRACUT.CONF
/ETC/SELINUX/SEMANAGE.CONF
/ETC/SELINUX/RESTORECOND_USER.CONF
/ETC/SELINUX/TARGETED/SETRANS.CONF
/ETC/SELINUX/RESTORECOND.CONF
......
[root@localhost ~]# ls -d /var/* 
/var/account  /var/cvs    /var/games  /var/lock  /var/nis       /var/run    /var/yp
/var/cache    /var/db     /var/lib    /var/log   /var/opt       /var/spool
/var/crash    /var/empty  /var/local  /var/mail  /var/preserve  /var/tmp
[root@localhost ~]# ls -d /var/* | wc -l
19
[root@localhost ~]# cat /etc/group | sort -t ':' -k3 -n | head -n10 
root:x:0:
bin:x:1:bin,daemon
daemon:x:2:bin,daemon
sys:x:3:bin,adm
adm:x:4:adm,daemon
tty:x:5:
disk:x:6:
lp:x:7:daemon
mem:x:8:
kmem:x:9:
[root@localhost ~]# cat /etc/group | sort -t ':' -k3 -n | head -n10 | cut -d ':' -f1
root
bin
daemon
sys
adm
tty
disk
lp
mem
kmem
[root@localhost ~]#  cat /etc/{fstab,issue} > /tmp/etc.test
[root@localhost ~]# cat /tmp/etc.test

#
# /etc/fstab
# Created by anaconda on Sun Jul  2 04:16:54 2017
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=e31be215-2c21-45f2-a43f-1a9c6bc383f2 /                       ext4    defaults        1 1
UUID=e21d7c4d-25ec-4dd5-aa07-a30d93fa7c21 /boot                   ext4    defaults        1 2
UUID=c0171f40-f6da-4511-adde-49d051567eb2 /home                   ext4    defaults        1 2
UUID=07042df1-e750-4be6-9a53-ce80e0cd84a0 swap                    swap    defaults        0 0
tmpfs                   /dev/shm                tmpfs   defaults        0 0
devpts                  /dev/pts                devpts  gid=5,mode=620  0 0
sysfs                   /sys                    sysfs   defaults        0 0
proc                    /proc                   proc    defaults        0 0
CentOS release 6.3 (Final)
Kernel \r on an \m
上一篇下一篇

猜你喜欢

热点阅读