linux通配符與正則表達式

通配符

  *  任意字符,可重複屢次正則表達式

    ? 任意字符,重複一次
bash

    [] 表明一個字符ide

舉例: [a,b,c] 表示abc中任意一個oop

通配符的做用是用來匹配文件名的ip

正則表達式

正則表達式是在文件中匹配符合條件的字符串的hadoop

ls find cp是不支持正則表達式的資源

可是grep awk sed支持正則表達式字符串

複製代碼

[root@hadoop-bigdata01 test]# touch aa[root@hadoop-bigdata01 test]# touch aab aabb[root@hadoop-bigdata01 test]# lltotal 0-rw-r--r-- 1 root root 0 May 16 19:47 aa-rw-r--r-- 1 root root 0 May 16 19:47 aab-rw-r--r-- 1 root root 0 May 16 19:47 aabb
[root@hadoop-bigdata01 test]# ls aaaa
[root@hadoop-bigdata01 test]# ls aa?aab
[root@hadoop-bigdata01 test]# ls aa*aa  aab  aabb

複製代碼

正則表達式特殊字符rpc

 

正則表達式匹配範圍it


正則表達式標準字符

使用正則表達式

 grep "1" /etc/passwd 

包含關鍵字1的行,grep只要包含就行,不想通配符,要徹底一致

複製代碼

[root@hadoop-bigdata01 test]# grep "1" /etc/passwdbin:x:1:1:bin:/bin:/sbin/nologin
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
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
wang:x:501:501::/home/wang:/bin/bash

複製代碼

grep 'root' /etc/passwd

cat /etc/passwd | grep 'root'

都是一樣的道理,可是管道符更吃資源

因此

1.匹配含有數字的行    

   grep '[0-9]' /etc/passwd

2.匹配連續含有三個數字的行

 grep '[0-9][0-9][0-9]' /etc/passwd            或者   grep ':[0-9][0-9][0-9]:' /etc/passwd 

複製代碼

[root@hadoop-bigdata01 test]# grep '[0-9][0-9][0-9]'  /etc/passwdgames:x:12:100:games:/usr/games:/sbin/nologin
usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
rtkit:x:499:497:RealtimeKit:/proc:/sbin/nologin
avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
saslauth:x:498:76:"Saslauthd user":/var/empty/saslauth:/sbin/nologin
pulse:x:497:496:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
liucheng:x:500:500::/home/liucheng:/bin/bash
wang:x:501:501::/home/wang:/bin/bas

複製代碼

3.匹配以r開頭 n結尾的行

 grep '^r.*n$' /etc/passwd

.*表明全部

[root@hadoop-bigdata01 test]# grep '^r.*n$'  /etc/passwd               rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin
rtkit:x:499:497:RealtimeKit:/proc:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin

4.過濾ifconfig ,截取ip

grep -v 表明反向截取,意思就是去除帶有某關鍵字的行    sed有替換的意思

複製代碼

[root@hadoop-bigdata01 test]# ifconfig | grep 'inet addr:'
          inet addr:192.168.126.191  Bcast:192.168.126.255  Mask:255.255.255.0
          inet addr:127.0.0.1  Mask:255.0.0.0[root@hadoop-bigdata01 test]# [root@hadoop-bigdata01 test]# ifconfig | grep 'inet addr:' | grep -v '127.0.0.1'
          inet addr:192.168.126.191  Bcast:192.168.126.255  Mask:255.255.255.0[root@hadoop-bigdata01 test]# ifconfig | grep 'inet addr:' | grep -v '127.0.0.1' | sed 's/inet addr://g'
          192.168.126.191  Bcast:192.168.126.255  Mask:255.255.255.0[root@hadoop-bigdata01 test]# ifconfig | grep 'inet addr:' | grep -v '127.0.0.1' | sed 's/inet addr://g' | sed 's/Bcast.*//g'
          192.168.126.191

複製代碼

誤區

這裏有個誤區,想了很久,是正則表達式和通配符的區別

咱們知道通配符的*指的是任意字符,可重複屢次 正則表達式的*指的是匹配前一個字符>=0次

這兩個是徹底不一樣的,那如何知道我用的*是通配符仍是正則表達式

起初我陷入一個誤區,看下面這串命令

複製代碼

[root@hadoop-bigdata01 test]# touch ac aac abc abbc[root@hadoop-bigdata01 test]# lltotal 0-rw-r--r-- 1 root root 0 May 16 19:55 aac-rw-r--r-- 1 root root 0 May 16 19:55 abbc-rw-r--r-- 1 root root 0 May 16 19:55 abc-rw-r--r-- 1 root root 0 May 16 19:55 ac
[root@hadoop-bigdata01 test]# ls | grep 'a*c'aac
abbc
abc
ac
[root@hadoop-bigdata01 test]# ls | grep 'a.*c'aac
abbc
abc
ac
[root@hadoop-bigdata01 test]# ls | grep '^a.*c'aac
abbc
abc
ac
[root@hadoop-bigdata01 test]# ls | grep '^a*c' aac
ac

複製代碼

爲何grep 'a*c'  和 grep '^a*c$' 的結果會不同,我覺得一個是通配符,一個是正則,由於a*c顯示的四個結果,正好

不就是匹配任意多個字符嗎?

其實否則

通配符的做用是用來匹配文件名的

正則表達式是在文件中匹配符合條件的字符串的

交給管道符以後使用grep已經不是匹配文件名了,這是對文件的操做,因此說,他徹底就是正則表達式

grep 'a*c' 表示的是匹配a>=0個因此只要含有c就是能夠的

而grep '^a*c$'也是正則,表示的是以a開頭,且第二個字符匹配a零次或者屢次,接下來是c字母的

因此只有aac 和ac 符合條件

因此看這個例子

複製代碼

[root@hadoop-bigdata01 test]# lsa  aac  abb  abbc  abc  ac  b  bb  c  cb
[root@hadoop-bigdata01 test]# ls | grep 'a*b'abb
abbc
abc
b
bb
cb

複製代碼

這裏grep 'a*b' 指的可不是含有a和b 而是a重複0次或者屢次而後含有b

相關文章
相關標籤/搜索