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