閱讀991 返回首頁    go 阿裏雲 go 技術社區[雲棲]


刪除文件時排除特定文件

刪除文件時排除特定文件
刪除當前目錄下所有 *.txt文件,除了test.txt
rm `ls *.txt|egrep -v test.txt`
或者
rm `ls *.txt|awk '{if($0 != "test.txt") print $0}'`
排除多個文件
rm `ls *.txt|egrep -v '(test.txt|fff.txt|ppp.txt)'`
---------------
rm -f `ls *.log.1|egrep -v '(access-2010-09-06.log|error-2010-09-06.log)'`
rm -f `ls *.log|egrep -v '(access-2010-09-06.log|error-2010-09-06.log)'`
---------------
rm -f `ls *.log|egrep -v '(20100906.log)'`
---------------
這裏是用ls得到原始數據,也可以用find命令
rm `find . -name *.txt | egrep -v ‘(test.txt|fff.txt|ppp.txt)'`


==========================================
egrep是grep的擴展, egrep除了具備grep的基本功能外還可以使用附加的正則表示式元字符, 如
[a-z]+A
[a-z]?A
[a-z]|[a-z]
abc(d|e)
等, 另外egrep不允許使用\(\)和\{\}

egrep 是 grep的擴展,使用 egrep的主要好處是其在 grep提供的正則表達式元字符集的基礎上增加了更多的元字符。不過,egrep 不支持 grep 的\(\)標記匹配字符和\{\}重複的功能。
下表給出了egrep新添的正則表達式元字符 元字符 功能 示例 匹配對象
+ 匹配1個或多個前一字符 ‘[a-z]+ove’ 匹配跟在一或多個小寫字母後麵的ove。將找出move,love等
? 匹配0個或1個前一字符 ‘lo?ve’ 匹配後麵跟一個或不跟字母o的l.將找到love或lve
a|b 匹配a或b ‘love|hate’ 匹配love和hate這兩個表達式之一
() 字符組 ‘love(able|ly)(ov)+’ 匹配loveable或lovely加上ov的一次或多次出現


grep、fgrep 和 egrep 命令


grep 命令一次隻能搜索一個指定的模式;egrep 命令檢索擴展的正則表達式(包括表達 式組和可選項);fgrep 命令檢索固定字符串,它不識別正則表達式,是快速搜索命令。

這 組命令在搜索與定位文件中特定的主題方麵非常有用。要搜索的模式可以被認為是一 些關鍵詞,您可以用它們來搜索文件中包含的這些關鍵詞。編寫程序時,可以用它來尋 找某一個函數,或是相關的詞組。grep 命令的搜索功能比 fgrep 強大,因為 grep 命令的搜索模式可以是正則表達式,而 fgrep 卻不能。

grep,egrep,fgrep用法

grep (global regular expression print)是一種文本過濾程序,按照正則表達式的規則,篩選出含有指定模式字符串的文本行。

1.作用

grep命令可以指定文件中搜索特定的內容,並將含有這些內容的行標準輸出。grep全稱是Global Regular Expression Print,表示全局正則表達式版本,它的使用權限是所有用戶。

2.格式

grep [options] PATTERN FILE

3.主要參數

grep [options]
[options]主要參數:
-c:隻輸出匹配行的計數。
-i:不區分大小寫(隻適用於單字符)。
-h:查詢多文件時不顯示文件名。
-l:查詢多文件時隻輸出包含匹配字符的文件名。
-n:顯示匹配行及行號。
-s:不顯示不存在或無匹配文本的錯誤信息。
-v:顯示不包含匹配文本的所有行。

pattern正則表達式主要參數:
\    忽略正則表達式中特殊字符的原有含義。
^ 匹配正則表達式的開始行。 
$ 匹配正則表達式的結束行。 
< 從匹配正則表達式的行開始。 
> 到匹配正則表達式的行結束。 
[ ] 單個字符集合,如[ABCD]即A,B,C,D任一字符符合要求 。 
[ - ] 範圍,如[A-Z],即A、B、C一直到Z都符合要求 。
. 所有的單個字符。 
*    重複字符,長度可以為0。 


正則表達式是Linux/Unix係統中非常重要的概念。正則表達式(也稱為“regex”或“regexp”)是一個可以描述一類字符串 的模式(Pattern)。如果一個字符串可以用某個正則表達式來描述,我們就說這個字符和該正則表達式匹配(Match)。這和DOS中用戶可以使用通 配符 “*”代表任意字符類似。在Linux係統上,正則表達式通常被用來查找文本的模式,以及對文本執行“搜索-替換”操作和其它功能。

4.應用實例

grep -n _DATE_ *.c 在所有後綴為.c文件中查找含有正則表達式_DATE_的行,並打印行號。

grep -v '[Dd]isable' device.stat>device.active 將文件device.stat中取消所有含有指定模式的行,生成新文件device.active

grep -i richard telnos 在文件telnos中檢索字符串richard,不顧字母的大小寫。

grep '[0-9]*' chapter1 由於[0-9]*與空字符串匹配,上述命令打印出charpter1文件中所有行,而不是僅打印出含有數字的行。正確的用法是 grep '[0-9][0-9]*' chapter1 或 egrep '[0-9]+' chapter1

查詢DNS服務是日常工作之一,這意味著要維護覆蓋不同網絡的大量IP地址。有時IP地址會超過2000個。如果要查看nnn.nnn網絡地址,但 是卻忘了第二部分中的其餘部分,隻知到有兩個句點,例如nnn nn..。要抽取其中所有nnn.nnn IP地址,使用[0-9 ]{3 }.[0-0{3}。含義是任意數字出現3次,後跟句點,接著是任意數字出現3次,後跟句點.

$grep '[0-9 ]{3 }.[0-0{3}.' ipfile

ipfile的內容
333.225.332.235 123.456.789.123 234.567.889.235
輸出結果
333.225.332.235 123.456.789.123 234.567.889.235

$grep '[0-9 ]{3 }.[0-9{3}.' -c ipfile
輸出結果
3
$grep '[0-9 ]{3 }.[0-9{3}.' -l ipfile
輸出結果
ipfile
$grep '[0-9 ]{3 }.[0-9{3}.' -n ipfile
輸出結果
1:333.225.332.235 2:123.456.789.123 3:234.567.889.235

補充說明,grep家族還包括fgrep和egrep。fgrep是fix grep,允許查找字符串而不是一個模式,運算速度快,適合於從大量數據中進行檢索;egrep是擴展grep,支持基本及擴展的正則表達式,可用()及|等,但不支持q模式範圍的應用及與之相對應的一些更加規範的模式。


該命令的各選項含義如下:

-E 每個模式作為一個擴展的正則表達式對待。 -F 每個模式作為一組固定字符串對待(以新行分隔),而不作為正則表達式。 -b 在輸出的每一行前顯示包含匹配字符串的行在文件中的字節偏移量。 -c 隻顯示匹配行的數量。 -i 比較時不區分大小寫。 -h 在查找多個文件時,指示grep不要將文件名加入到輸出之前。 -l 顯示首次匹配串所在的文件名並用換行符將其隔開。    當在某文件中多次出現匹配串時,不重複顯示此文件名。 -n 在輸出前加上匹配串所在行的行號(文件首行行號為1)。 -v 隻顯示不包含匹配串的行。 -x 隻顯示整行嚴格匹配的行。 -e expression 指定檢索使用的模式。用於防止以“-”開頭的模式被解釋為命令選項。 -f expfile 從expfile文件中獲取要搜索的模式,一個模式占一行。


轉載:https://blog.zol.com.cn/2322/article_2321781.html


最後更新:2017-04-04 07:03:42

  上一篇:go android EditText 設置彈出數字輸入法鍵盤
  下一篇:go Mac os X 常用技巧