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