學習shell的思想
思想(KISS)相當重要。KISS(keep it simple stupid)。
這是其實不難,只要按照一下思路進行就ok。
- 把復雜的問題簡單化,模塊化;
- 寫出每一個模塊的偽代碼;
- 組裝你的模塊;
- 寫出Shell Code;
- 測試(Test);
知道什么時候用什么實現(xiàn),遠比你知道怎么寫code更重要。(shell不是萬能的,擇優(yōu)取之。)shell最精華、最美的地方在于他有現(xiàn)成的命令可以使用,不用考慮底層的問題。作為上層工作最好的工具,所謂上層指的是系統(tǒng)管理、網(wǎng)絡(luò)管理等等。
討厭的正則
我們平常只所以討厭一個事物,本質(zhì)是因為自己駕馭不了它。比如你討厭一個人,是因為你一開始就以易于對待他人的方法和心態(tài)去和他溝通和接觸。
如何駕馭正則
1、亂七八糟的符號
舉例:grep是行模式,默認以行顯示

如上顯示三行

如上顯示兩行

如上顯示一行
總結(jié)什么是正則,兩個單引號中間的部分就是正則。
正則有什么用
查找匹配
正則提供了一些特殊符號,通過這些符號去替換一些東西。
1、一個字符(如何在整篇文章中查找一個字符)
舉例:在整篇文章中查找字母a
使用vi編輯器打開/etc/passwd, 在末行模式下查找a
輸入 :/a/
還有你想要查找abc,是查找一個是或的關(guān)系,也就是說要找a,ab,ac,b,bc,c,abc這樣的情況,那么就用[]來表示。
輸入 :/[abc]/ or :/[a-c]/ or :/a|b|c/
中括號,就是把你想要定位的東西寫入到里面。
任意一個字符
[] 選擇中括號里面的任意一個
[^] 取反,取非
[:alnum:] 阿爾法字符加數(shù)字
[:alpha:] 任意一個字符 [[:alpha]]
[:digit:] 任意一個數(shù)字 [[:digit:]](對它取反的話[^[:digit:]])意為除了任意一個數(shù)字。
[:lower:] 小寫
[:upper:] 大寫
[:space:] 空格
[:punct:] 標點
以上用什么定位一個字符,請看下面

如下圖 -E 代表的是一個擴展表達式。其中dp之間的
|代表的是或的關(guān)系,任意取一。
轉(zhuǎn)義字符:\
Example: 當 . 在這不轉(zhuǎn)義的時候代表的是正則中的 . 代表匹配任意一個字符.

當
\. 轉(zhuǎn)義之后代表著文本中真正真實存在我們看到的具體的 .
2、字符的邊界, 查找匹配多個字符需要用到字符邊界
^ 開頭(一行開頭)
$ 結(jié)尾(一行結(jié)尾)
\< 左邊界
\> 右邊界

cat -A /etc/passwd

顯示其字符邊界。
Linux下 dos2unix 命令可以吧windows格式文件轉(zhuǎn)換為Linux, unix2dos 命令可以把Linux格式轉(zhuǎn)為Windows
3、重復
* 重復0次或多次, 注意命令 ls * 中的 * 不是正則,是shell中的通配符;正則中 * 代表前面出現(xiàn)0次或者多次。 * > = 0
Example: 匹配所有字符,字符每個出現(xiàn)次數(shù)大于等于0次


a的次數(shù)大于等于0次,字符中沒有a,它相當于沒有,所以匹配所有,但是不會高亮顏色,因為沒有a.

上圖可以看出第2、5行沒有d,那如果要只匹配d的行打印出來咋整:

+ 匹配一個或者多個 + >= 1Example:匹配d,
d+ 代表每一行匹配d的次數(shù)大于等于1
? 匹配0個或者1個 <= 1Example:

精確匹配次數(shù)
{} 中填入數(shù)字代表匹配次數(shù),大于等于次數(shù)的行被匹配出來
Example: a精確匹配5次,a出現(xiàn)的次數(shù)大于等于5次的行被匹配出來.

精確到范圍
{n,m} Example: {3,5} 匹配3至5,包括3和5.

4、組
組的重復
Example:pig 一組,dog一組。 其中 | 有或的意思,如果有組 pig或者dog,就匹配出這一樣.

pig一組,dog一組。 pig或者dog出現(xiàn)的次數(shù)大于等于1,就匹配這一樣。

pig一組,dog一組。pig或者dog出現(xiàn)滿足某一行精確到出現(xiàn)兩次就匹配。

本文通過
Linux天使團的討厭的Shell正則整理。