linux去除文件空行

北城余情 提交于 2020-01-19 20:25:49

方法一:利用grep

grep -v '^\s*$' test.txt > new_file

注:-v表示将匹配的结果进行反转,正则表达式匹配空行。(空行可包括空格符、制表符等空白字符)

方法二:利用sed

sed '/^\s*$/d' test.txt > new_file

注:d代表删除该行

或者:sed -i '/^\s*$/d' test.txt

方法三:利用awk

awk NF test.txt > new_file

注:NF代表当前行的字段数,空行的话字段数为0,被awk解释为假,因此不进行输出。

以上三种方式均可处理包含空白字符(空格符、制表符等)的空行。

方法四:若空行均由'\n'造成,则还可以利用tr命令去除空行

tr -s '\n' < test.txt > new_file

注:-s代表将多个连续的字符压缩成一个字符,这里是将多个'\n'压缩成一个'\n',达到去除空行的效果。方法四的缺陷:如果首行就出现空行的话则无法去除首行的空行。

相关拓展:

查看重复的行 sort -n test.txt | uniq -d

一、两个文件的交集,并集

1、取出两个文件的并集(重复的行只保留一份)

cat file1 file2 | sort | uniq > file3

2、取出两个文件的交集(只留下同时存在于两个文件中的文件)

cat file1 file2 | sort | uniq -d > file3

3、删除交集,留下其他的行

cat file1 file2 | sort | uniq -u > file3

二、两个文件合并

一个文件在上,一个文件在下

cat file1 file2 > file3

一个文件在左,一个文件在右

paste file1 file2 > file3

三、一个文件去掉重复的行

sort file | uniq

重复的多行记为一行,每批重复的行会保留一行,等同于去重

sort file | uniq -u

把重复的行全部去掉,只输出文件中的非重复行

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!