學習shell的思想
思想(KISS)相當重要。KISS(keep it simple stupid)。
這是其實不難,只要按照一下思路進行就ok。
- 把復雜的問題簡單化,模塊化;
- 寫出每一個模塊的偽代碼;
- 組裝你的模塊;
- 寫出Shell Code;
- 測試(Test);
知道什么時候用什么實現(xiàn),遠比你知道怎么寫code更重要。(shell不是萬能的,擇優(yōu)取之。)shell最精華、最美的地方在于他有現(xiàn)成的命令可以使用,不用考慮底層的問題。作為上層工作最好的工具,所謂上層指的是系統(tǒng)管理、網(wǎng)絡管理等等。
討厭的正則
我們平常只所以討厭一個事物,本質(zhì)是因為自己駕馭不了它。比如你討厭一個人,是因為你一開始就以易于對待他人的方法和心態(tài)去和他溝通和接觸。
如何駕馭正則
1、亂七八糟的符號
舉例:grep是行模式,默認以行顯示
如上顯示三行
如上顯示兩行
如上顯示一行
總結什么是正則,兩個單引號中間的部分就是正則。
正則有什么用
查找匹配
正則提供了一些特殊符號,通過這些符號去替換一些東西。
1、一個字符(如何在整篇文章中查找一個字符)
舉例:在整篇文章中查找字母a
使用vi編輯器打開/etc/passwd, 在末行模式下查找a
輸入 :/a/
還有你想要查找abc,是查找一個是或的關系,也就是說要找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之間的
|
代表的是或的關系,任意取一。轉(zhuǎn)義字符:\
Example: 當 .
在這不轉(zhuǎn)義的時候代表的是正則中的 .
代表匹配任意一個字符.
當
\.
轉(zhuǎn)義之后代表著文本中真正真實存在我們看到的具體的 .
2、字符的邊界, 查找匹配多個字符需要用到字符邊界
^
開頭(一行開頭)
$
結尾(一行結尾)
\<
左邊界
\>
右邊界
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的行打印出來咋整:
+
匹配一個或者多個 + >= 1
Example:匹配d,
d+
代表每一行匹配d
的次數(shù)大于等于1?
匹配0個或者1個 <= 1
Example:
精確匹配次數(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正則整理。