我在Linux中尝试了grep -v '^$',但没有工作。该文件来自Windows文件系统。
当前回答
试试下面的方法:
grep -v -e '^$' foo.txt
e选项允许正则表达式模式进行匹配。
^$周围的单引号使它适用于shell。其他shell只接受单引号或双引号。
更新:这适用于一个有空行或“全空白”的文件(如windows行带\r\n样式的行结束符),而上面只删除有空行和unix样式行结束符的文件:
grep -v -e '^[[:space:]]*$' foo.txt
其他回答
使用Perl:
perl -ne 'print if /\S/'
\S表示匹配非空字符。
保持简单。
grep . filename.txt
Egrep -v "^\s\s+"
Egrep已经做了正则表达式,\s是空白。
+复制当前模式。
^表示开始
Use:
grep pattern filename.txt | uniq
从文件中读取行排除空行
grep -v '^$' folderlist.txt
folderlist.txt
folder1/test
folder2
folder3
folder4/backup
folder5/backup
结果如下:
folder1/test
folder2
folder3
folder4/backup
folder5/backup
推荐文章
- 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不区分大小写的字符串?
- 我如何使用换行符'\n'在f字符串格式化输出?