我在Linux中尝试了grep -v '^$',但没有工作。该文件来自Windows文件系统。
当前回答
与之前的答案相同:
grep -v -e '^$' foo.txt
这里,grep -e表示grep的扩展版本。'^$'表示^(行首)和$(行尾)之间没有任何字符。'^'和'$'是正则表达式字符。
因此,命令grep -v将打印所有不匹配此模式的行(^和$之间没有字符)。
这样,空行就被消除了。
其他回答
此代码删除空行和以“#”开头的行
grep -v "^#" file.txt | grep -v ^[[:space:]]*$
我更喜欢使用egrep,尽管在我的测试中,您的方法工作得很好(尽管在我的测试中没有引号)。这个方法也奏效了:
egrep -v "^(\r?\n)?$" filename.txt
Use:
grep pattern filename.txt | uniq
如果在一行中有多个空行序列,并且每个序列只希望有一个空行,请尝试
grep -v "unwantedThing" foo.txt | cat -s
Cat -s抑制重复的空输出行。
你的输出会从
match1
match2
to
match1
match2
原始输出中的三个空行将被压缩或“压缩”为一个空行。
Use:
$ dos2unix file
$ grep -v "^$" file
或者简单地awk:
awk 'NF' file
如果你没有dos2unix,那么你可以使用像tr这样的工具:
tr -d '\r' < "$file" > t ; mv t "$file"
推荐文章
- 如何从终端/命令行调用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