繁体   English   中英

sed-如果行未以\\结尾,请删除换行符

[英]sed - remove line break if line does not end on \"

我有一个tsv。文件,有些行不以'“'结尾,所以现在我想删除不是直接在'”'之后的所有换行符。 我怎么能用sed做到这一点? 或任何其他bash shell程序...

亲切的问候,斯纳夫

sed命令应执行以下操作:

sed '/"$/!{N;s/\n//}' file

它说:在不匹配的每一行上, "$ do:

  • 阅读下一行,将其附加到模式空间;
  • 删除两行之间的换行符。

例:

$  cat file.txt
"test"
"qwe
rty"
foo
$  sed '/"$/!{N;s/\n//}' file.txt
"test"
"qwerty"
foo

为了详细说明@Lev的答案, sed的BSD(OSX)版本对花括号中的命令语法不太宽容-这两个命令都需要使用分号命令分隔符:

sed '/"$/!{N;s/\n//;}' file.txt

根据此处的文档 -摘录:

在地址或地址范围之后,sed接受大括号“ {...}”,因此可以在该行或该地址范围匹配的行上应用几个命令。 在命令行上,分号“;” 分开每条指令,并且必须在大括号之前。

试试这个awk一线尝试:

awk '{printf "%s%s",$0,(/"$/?"\n":"")}' file

测试

kent$  cat f
"foo"
"bar"
"a long
text with
many many
lines"
"lalala"

kent$  awk '{printf "%s%s",$0,(/"$/?"\n":"")}' f
"foo"
"bar"
"a longtext withmany manylines"
"lalala"

这可能对您有用(GNU sed):

sed ':a;/"$/!{N;s/\n//;ta}' file

这将检查模式空间的最后一个字符是否为" ,如果不是,则追加另一行,删除换行符并重复执行,直到满足条件或遇到文件结尾为止。

一种替代方法是:

sed -r ':a;N;s/([^"])\n/\1/;ta;P;D' file

该机制留给读者思考。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM