我在Linux中尝试了grep -v '^$',但没有工作。该文件来自Windows文件系统。
当前回答
保持简单。
grep . filename.txt
其他回答
使用Perl:
perl -ne 'print if /\S/'
\S表示匹配非空字符。
grep -v "^[[:space:]]*$"
The -v makes it print lines that do not completely match
===Each part explained===
^ match start of line
[[:space:]] match whitespace- spaces, tabs, carriage returns, etc.
* previous match (whitespace) may exist from 0 to infinite times
$ match end of line
〇运行代码
$ echo "
> hello
>
> ok" |
> grep -v "^[[:space:]]*$"
hello
ok
要了解更多关于这是如何/为什么工作的,我建议阅读正则表达式。http://www.regular-expressions.info/tutorial.html
的确,使用grep -v -e '^$'可以工作,但是它不能删除有1个或多个空格的空行。我发现删除空行最简单的答案是使用awk。下面是对上面awk的修改:
awk 'NF' foo.txt
但由于这个问题是为了使用grep,我将回答以下问题:
grep -v '^ *$' foo.txt
注意:^和*之间有空格。
或者你可以用\s来表示空格,就像这样:
grep -v '^\s*$' foo.txt
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
推荐文章
- 如何从终端/命令行调用VS代码编辑器
- 为什么在Mac OS X v10.9 (Mavericks)的终端中apt-get功能不起作用?
- 在Windows中有像GREP这样的模式匹配实用程序吗?
- “你有邮件”的消息在终端,os X
- 如何从命令行将每两行合并为一行?
- 匹配前后的Grep字符?
- nvarchar(max)非文本
- (grep)正则表达式匹配非ascii字符?
- 如何从另一个文件A中删除文件B中出现的行?
- 如何使制表符4个空间而不是8个空间在纳米?
- 如何强制从另一个SSH会话分离屏幕?
- 如何从终端机发送电子邮件?
- OpenGL 4.1版本的文本渲染技术是怎样的?
- 谁能举一个余弦相似度的例子,用一个简单的图形化的方法?
- 在SQL Server上使用varchar(MAX) vs TEXT