一尘不染

如何在UNIX中删除文件的最后一个字符?

linux

说我有一些任意的多行文本文件:

sometext
moretext
lastline

如何在不使文本文件无效的情况下仅删除文件的最后一个字符(e,而不是换行符或null)?


阅读 289

收藏
2020-06-02

共1个答案

一尘不染

一个更简单的方法( 输出到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
2020-06-02