说我有一些任意的多行文本文件:
sometext
moretext
lastline
如何在不使文本文件无效的情况下仅删除文件的最后一个字符(e,而不是换行符或null)?
解决方法:
一种更简单的方法(输出到stdout,不更新输入文件):
sed '$s/.$//' somefile
> $是仅与最后一行输入行匹配的Sed地址,因此导致以下函数调用(s /.$//)仅在最后一行执行.
> s /.$//用空字符串替换(在本例中为last)行的最后一个字符;即,有效地删除最后一个字符. (换行前)上线.
.匹配该行上的任何字符,并使用$anchors将其匹配到该行的末尾;注意这个正则表达式中$的使用在概念上是如何相关的,但在技术上与以前使用$作为Sed地址有所区别.
> stdin输入示例(假设Bash,Ksh或Zsh):
$sed '$s/.$//' <<< $'line one\nline two'
line one
line tw
要更新输入文件(如果输入文件是符号链接,请不要使用):
sed -i '$s/.$//' somefile
注意:
*在OSX上,您必须使用-i”而不仅仅是-i;有关与-i相关的陷阱的概述,请参见my answer here的下半部分.
*如果您需要处理非常大的输入文件和/或性能/磁盘使用是一个问题,并且您正在使用GNU实用程序(Linux),请参阅sorontar’s helpful answer.
标签:bash,linux,sed,unix
来源: https://codeday.me/bug/20190923/1815365.html