linux中Shell如何去掉空行

发布时间:2021-10-27 14:27:49 作者:小新
来源:亿速云 阅读:375

小编给大家分享一下linux中Shell如何去掉空行,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

1. grep

$ grep -v '^$' file

-v 用于输出不匹配的内容:

$ man grep   Matching Control   -v, --invert-match                Invert the sense of matching, to select non-matching lines.

通配符 '^里的用于表示字符串开始, 用于表示字符串结束。

2. sed

$ sed '/^$/d' file

sed 的全名是 “stream editor”,即流编辑器,是一个使用简单紧凑的编程语言来解析和转换文本超强实用程序。

^$ 用于匹配空白行,d 则是 sed 的其中一个命令,用于删除匹配项:

$ man sed  COMMAND SYNOPSIS      ...      d      Delete pattern space.  Start next cycle.      ...

3. awk

$ awk '!/^$/' file

补充知识:

awk (其名称得自于它的创始人阿尔佛雷德·艾侯、彼得·温伯格和布莱恩·柯林汉姓氏的首个字母) 是一种用于处理文本的编程语言。它是一个优良的文本处理工具,工作时它会扫描文件中的每一行,查找与命令行中所给定内容相匹配的模式。如果发现匹配内容,则进行下一个编程步骤。如果找不到匹配内容,则继续处理下一行。

awk 程序是由一系列模式--动作对组成的:

pattern { action }

回到我们的需求,^$ 用于匹配空白行,!则用来取反,从而找出非空白行,awk 的默认 action 就是 print,所以我们连 print 都不写了。

4. tr

$ cat in.txt | tr -s '\n'

tr 是 translate 的缩写,用于替换或删除输入数据集中特定字符。

-s 用于将其输出中相同相邻字符的序列压缩为单个字符:

$ man tr  DESCRIPTION      -s, --squeeze-repeats                replace  each  sequence  of a repeated character that is listed in the last specified SET, with a single occurrence of                that character

5. vi

$ vi file  :g/^$/d

以上是“linux中Shell如何去掉空行”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. python逐行读取文件脚本并去掉空行
  2. Linux—删除文本、文件中的空行

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

shell linux

上一篇:vue如何获取dom元素

下一篇:在java中如何编写规范的代码

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》