Linux特殊字符淺談
我們經常跟鍵盤上面那些特殊符號比如(?、!、~...)打交道,其實在Linux有其獨特的含義,大致可以分為三類:Linux特殊符號、通配符、正則表達式。
Linux特殊符號又可以分以下幾類
1、管道符號
| 字符 |
名稱 |
功能描述 |
| | |
管道 |
傳遞的普通的字符串,來自於前一個命令 |
| |xargs |
管道流轉換 |
與xargs 傳遞的是把字符串變成了文件名 |
2、目錄結構
| 字符 |
名稱 |
功能描述 |
| . |
|
當前目錄 |
| .. |
|
當前目錄上一級目錄 |
3、重定向符號
| 字符 |
名稱 |
功能描述 |
| > |
輸出重定向 |
會清空原文以及內容 然后在向文件里面追加內容 |
| >> |
追加輸出重定向 |
追加到文件最后一行 |
| < |
輸入重定向 |
文本內容輸入 tr xargs |
| << |
追加輸入重定向 |
用於給文件追加多行文本 cat |
4、其他特殊符號
| 字符 |
名稱 |
功能描述 |
| # |
注釋 |
Linux注釋,另#root 超級用戶提示符 |
| $ |
變量符號 |
shell、$變量取值、AWK取列等 |
| && |
表示並且 |
前面部分執行成功才執行后面的部分 |
| || |
表示或者 |
前面部分執行失敗才執行后面的部分 |
| `` |
Shell執行命令 |
引用命令的結果 |
| ; |
命令分割 |
一行分割多個命令,沒有邏輯聯系 |
| ‘’ |
設置字符串變量 |
不具有變量置換功能,輸出時所見即所得 |
| “” |
設置字符串變量 |
具有變量置換功能,解析變量輸出 |
| {} |
表示序列 |
以逗號分割,且不能為空,如{a,b,c}表示單獨 {0..9}表示范圍,同功能的有seq,但seq只產生數字序列 |
| - |
|
cd - su - root |
| ~ |
|
當前目錄的家目錄 |
| / |
|
根或者路徑分割 |
| ! |
|
vi/vim強制退出 邏輯運算非, !+字母 調出最近一次以字母開頭的命令 !!使用 最近一次操作的命令 !+數字 調出歷史的第幾條命令 |
通配符:通常匹配文件名
| 字符 |
名稱 |
功能描述 |
| ? |
|
匹配任一個字符(不在括號內的時候) |
| * |
|
匹配任何字符(0或多個) |
| [] |
|
匹配符號內任一字符 如[abcd] [0-9] |
| [!]非 |
|
表示不匹配[]里面任一字符 |
正則表達式:處理大量的字符串,通常以行為單位(簡單高效)
基礎正則BRE
| 字符 |
名稱 |
功能描述 |
| ^ |
|
以某某開頭的 |
| $ |
|
以某某結尾的 |
| ^$ |
|
空行,不是空格 |
| . |
|
表示任意一個字符 |
| \ |
元字符轉義普通字符 |
\. 普通字符小數點 \n 換行符 \b 單詞邊界 \r 回車 \t 橫向制表符 |
| * |
|
重復之前的字符0個或者多個 |
| .* |
|
匹配所有字符 |
| ^.* |
|
以任意多個字符開頭 |
| .*$ |
|
以任意多個字符結尾 |
| [] |
|
匹配字符串內的任意一個字符,如[abc]匹配a或b或c,[a-z]匹配所有小寫字母 |
| [^] |
|
匹配不包含字符串內的任意字符,取反 |
擴展正則ERE(使用egrep或者sed -r)
| 字符 |
名稱 |
功能描述 |
| + |
|
重復前一個字符一次或一次以上,如[0-9]+ |
| ? |
|
重復前一個字符0次或者一次 |
| | |
|
元字符左邊字符或者右邊字符 |
| () |
|
分組過濾,如()內的內容為一個整體;反向引用:如\1表示引用第一個()里面的內容 |
| a{n,m} |
|
重復前面a字符n到m次,egrep或者sed -r直接使用,如grep,sed使用該功能需要轉義a\{n,m\} |
| a{n,} |
|
重復前面a字符至少n次 |
| a{n} |
|
重復前面a字符n次 |
| a{,m} |
|
重復前面a字符最多m次 |
學習正則表達,我們可以使用Linux運維三劍客:awk、sed、grep;除了前三者,正則表達式還支持各種編程或者腳本語言
為了更好的學習和工作,我們一般自動添加顏色來區分匹配關鍵字
cat >> /etc/bashrc << EOF
alias egrep='egrep --color=auto'
alias grep='grep --color=auto'
EOF
source /etc/bashrc
學習步驟:
1:grep /RE/ filename
2:grep -o /RE/ filename 看它如何匹配
區分正則表達式和通配符
表達式是文件或者目錄名 -->通配符
表達式是文件內容(字符串) -->正則表達式
學習正則方法:awk、sed -r、grep/egrep -o:該都是匹配正則,其他都是通配符
幫助文檔:通配符man 7 glob
正則表達式:man grep、info grep等等
舉例:
1、/etc/hosts 取該文件權限對應的數字內容 如:-rw-r--r--對應的為644
思路方法:sed 正則、awk 分割符、grep、cut、ls 替換、stat、head
stat /etc/hosts | sed -n '4p' | sed 's#^.*(0##g' | sed 's#/.*$##g'
stat /etc/hosts | sed -rn '4s#^.*\(0(.*)/-.*$#\1#gp'
stat /etc/hosts | awk 'NR==4' | awk -F "0" '{print $2}' | cut -c 1-3
stat /etc/hosts | awk 'NR==4' | awk -F "0" '{print $2}' | awk -F "/" '{print $1}'
stat /etc/hosts | awk 'NR==4' | awk -F "[0/]" '{print $2}'
stat /etc/hosts | awk 'NR==4' | awk -F "0|/" '{print $2}'
stat /etc/hosts | awk -F "[0/]" 'NR==4{print $2}'
ls -l /etc/hosts | cut -c 2-10 | tr "rwx-" "4210" | awk -F "" '{print $1+$2+$3 $4+$5+$6 $7+$8+$9}'
ls -l /etc/hosts | cut -c 2-10 | tr "rwx-" "4210" | awk -F "" '{for(i=1;i<=NF;i++){if(i<4){user[a]+=$i}else if(i>3&&i<7){group[b]+=$i}else{other[c]+=$i}};print user[a]group[b]other[c]}'
ls -l /etc/hosts | awk -F "" '{gsub("r","4")};{gsub("w","2")};{gsub("x","1")};{gsub("-","0");print $2+$3+$4 $5+$6+$7 $8+$9+$10}'
2、取IP地址
ifconfig eth0 | awk -F "[ :]+" 'NR==2{print $4}'
ifconfig eth0 | awk -F "addr:| Bcast:" 'NR==2{print $2}'
