Shell中如何删除文本比较长的行

有的时候需要对文件执行删除删除操作,这个时候比较常用的会使用vi命令中的dd命令,比如先执行10G(跳转到第10行),然后再执行20dd(删除20行),但实际情况未必是这么常规,比如说,要删除文件中,某行长度超过200个字符的行,如果文本比较小,还好,如果是几万行,几十万行的呢? 这个想用vi就不现实了。 我然想到的办法就是:比如说,通过sed,awk,egrep命令来达到目的。 举个简单例子。

假如说如下文本文件,要将其中长度为5字符以上的给删除掉。

root@linux# cat data
1
22
333
4444
55555
666666
7777777
88888888

方法一: 使用awk命令的length()函数

root@linux# cat data | awk '{if (length($0) <=4 ) print $0}'
1
22
333
4444
方法二: 使用grep命令

root@linux# cat data | egrep -w '^.{1,4}'
1
22
333
4444

方法三: 使用sed命令

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文件

相关文章

用的openwrt路由器,家里宽带申请了动态公网ip,为了方便把2...
#!/bin/bashcommand1&command2&wait从Shell脚本并行...
1.先查出MAMP下面集成的PHP版本cd/Applications/MAMP/bin/ph...
1、先输入locale-a,查看一下现在已安装的语言2、若不存在如...
BashPerlTclsyntaxdiff1.进制数表示Languagebinaryoctalhexa...
正常安装了k8s后,使用kubect工具后接的命令不能直接tab补全...