我在Linux中尝试了grep -v '^$',但没有工作。该文件来自Windows文件系统。
当前回答
使用Perl:
perl -ne 'print if /\S/'
\S表示匹配非空字符。
其他回答
试试下面的方法:
grep -v -e '^$' foo.txt
e选项允许正则表达式模式进行匹配。
^$周围的单引号使它适用于shell。其他shell只接受单引号或双引号。
更新:这适用于一个有空行或“全空白”的文件(如windows行带\r\n样式的行结束符),而上面只删除有空行和unix样式行结束符的文件:
grep -v -e '^[[:space:]]*$' foo.txt
我更喜欢使用egrep,尽管在我的测试中,您的方法工作得很好(尽管在我的测试中没有引号)。这个方法也奏效了:
egrep -v "^(\r?\n)?$" filename.txt
如果在一行中有多个空行序列,并且每个序列只希望有一个空行,请尝试
grep -v "unwantedThing" foo.txt | cat -s
Cat -s抑制重复的空输出行。
你的输出会从
match1
match2
to
match1
match2
原始输出中的三个空行将被压缩或“压缩”为一个空行。
从文件中读取行排除空行
grep -v '^$' folderlist.txt
folderlist.txt
folder1/test
folder2
folder3
folder4/backup
folder5/backup
结果如下:
folder1/test
folder2
folder3
folder4/backup
folder5/backup
Use:
grep pattern filename.txt | uniq
推荐文章
- 如何强制从另一个SSH会话分离屏幕?
- 如何从终端机发送电子邮件?
- OpenGL 4.1版本的文本渲染技术是怎样的?
- 谁能举一个余弦相似度的例子,用一个简单的图形化的方法?
- 在SQL Server上使用varchar(MAX) vs TEXT
- PowerShell等价于grep -f
- 用CSS截断长字符串:可行吗?
- Git显示“警告:永久添加到已知主机列表”
- Awk不打印换行符
- 写字符串到文本文件,并确保它总是覆盖现有的内容。
- Docker- compose无法连接到Docker Daemon
- 字符串资源新行/n不可能?
- 如何复制文件跨计算机使用SSH和MAC OS X终端
- 如何修改文本文件?
- 如何读一个文本文件到一个列表或数组与Python