说我有一些任意的多行文本文件:
sometext
moretext
lastline
如何在不使文本文件无效的情况下仅删除文件的最后一个字符(e,而不是换行符或null)?
一种更简单的方法(将输出输出到stdout,不更新输入文件):
sed '$ s/.$//' somefile
$
是仅与最后一个输入行匹配的Sed地址,因此导致s/.$//
仅在最后一行执行以下函数调用()。s/.$//
用空字符串替换(在本例中为last)行的最后一个字符;即,有效地删除最后一个字符。(在换行符之前)。.
匹配该行上的任何字符,并在其后跟$
将匹配项锚定到该行的末尾;请注意,$
在此正则表达式中的用法在概念上是相关的,但在技术上与先前将其$
用作Sed 地址不同。使用stdin输入的示例(假设Bash,Ksh或Zsh):
$ sed '$ s/.$//' <<< $'line one\nline two'
line one
line tw
要更新输入文件太多(如果输入文件是符号链接,不要使用):
sed -i '$ s/.$//' somefile
注意:
*在OSX上,您必须使用-i ''
而不是-i
; 有关相关陷阱的概述-i
,请参见我的答案的下半部。
*如果您需要处理非常大的输入文件和/或性能/磁盘使用情况,并且您正在使用GNU实用程序(Linux),请参阅sorontar的有用答案。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句