我在Linux中尝试了grep -v '^$',但没有工作。该文件来自Windows文件系统。
当前回答
Use:
grep pattern filename.txt | uniq
其他回答
保持简单。
grep . filename.txt
Use:
grep pattern filename.txt | uniq
试试下面的方法:
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 -e '^$' foo.txt
这里,grep -e表示grep的扩展版本。'^$'表示^(行首)和$(行尾)之间没有任何字符。'^'和'$'是正则表达式字符。
因此,命令grep -v将打印所有不匹配此模式的行(^和$之间没有字符)。
这样,空行就被消除了。
推荐文章
- 如何从终端机发送电子邮件?
- 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
- 如何在文件中grep不区分大小写的字符串?