Shell中如何刪除文本比較長(zhǎng)的行的實(shí)現(xiàn)方法
有的時(shí)候需要對(duì)文件執(zhí)行刪除刪除操作,這個(gè)時(shí)候比較常用的會(huì)使用vi命令中的dd命令,比如先執(zhí)行10G(跳轉(zhuǎn)到第10行),然后再執(zhí)行20dd(刪除20行),但實(shí)際情況未必是這么常規(guī),比如說,要?jiǎng)h除文件中,某行長(zhǎng)度超過200個(gè)字符的行,如果文本比較小,還好,如果是幾萬行,幾十萬行的呢? 這個(gè)想用vi就不現(xiàn)實(shí)了。 我然想到的辦法就是:比如說,通過sed,awk,egrep命令來達(dá)到目的。 舉個(gè)簡(jiǎn)單例子。
假如說如下文本文件,要將其中長(zhǎng)度為5字符以上的給刪除掉。
1
2
3
4
5
6
7
8
9
|
root@linux # cat data 1 22 333 4444 55555 666666 7777777 88888888 |
方法一: 使用awk命令的length()函數(shù)
1
2
3
4
5
|
root@linux # cat data | awk '{if (length($0) <=4 ) print $0}' 1 22 333 4444 |
方法二: 使用grep命令
1
2
3
4
5
|
root@linux # cat data | egrep -w '^.{1,4}' 1 22 333 4444 |
方法三: 使用sed命令
1
2
3
4
5
6
|
root@linux # cat data | sed -n '/^.\{5,\}/!w NewFile' root@linux # cat NewFile 1 22 333 4444 |
備注:
1. 使用awk,grep命令的時(shí)候,可以將處理好的文件重定向到另外一個(gè)新文件中
2. egrep -w參數(shù),表示僅跟模式匹配的單詞
3. ^. 表示以任意字符開頭的行,這個(gè)和-w命令匹配使用,這個(gè)很關(guān)鍵,否則找不到
4. !w !表示所有模式不匹配的,w是輸出,寫入到新文件NewFile文件中
如有疑問請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
原文鏈接:http://blog.csdn.net/jerry_1126/article/details/77871972