说我有一些任意的多行文本文件:
sometext moretext lastline
如何在不使文本文件无效的情况下仅删除文件的最后一个字符(e,而不是换行符或null)?
一个更简单的方法( 输出到stdout ,不更新输入文件):
sed '$ s/.$//' somefile
$
s/.$//
s/.$//用空字符串替换(在本例中为 last )行的 最后 一个字符;即,有效地删除最后一个字符。(在换行符之前)。 .匹配该行上的任何字符,并在其后跟$将匹配项锚定到该行的末尾;请注意,$在此 正则表达式中 的用法在概念上是相关的,但在技术上与先前将其$用作Sed 地址不同 。
.
使用stdin输入的示例(假设Bash,Ksh或Zsh):
$ sed '$ s/.$//' <<< $'line one\nline two'
line one line tw
要 更新输入文件 太多(如果输入文件是符号链接,不要使用):
sed -i '$ s/.$//' somefile