从unix中的倒数第二行删除一个字符

use*_*991 3 unix linux bash awk sed

我们如何从unix文件的倒数第二行中删除字符?

例如,我有一个内容如下的文件:

aaa
bbb*
ccc*
ddd*
eee
Run Code Online (Sandbox Code Playgroud)

我的输出应该是:

aaa
bbb*
ccc*
ddd
eee
Run Code Online (Sandbox Code Playgroud)

有什么想法吗?

Tho*_*hor 5

使用sed在单次传递中执行此操作的一般方法是使用滑动窗口,类似于GNU sed手册中所述.

由于您只对第二行到最后一行的替换感兴趣,因此不需要保留空间.在这种情况下,单个N就足够了:

sed 'N; $! { P; D; }; s/.\n/\n/'
Run Code Online (Sandbox Code Playgroud)

或者作为BSD sed兼容脚本:

sed 'N; $! { P; D; }; s/.\n/\
/'
Run Code Online (Sandbox Code Playgroud)

输出:

aaa
bbb*
ccc*
ddd
eee
Run Code Online (Sandbox Code Playgroud)

说明

  • N命令为模式空间添加第二行.
  • $!当我们没有到达最后一行时,将评估该块.
  • { P; D; }打印第一行模式空间并删除它.在D具有重新启动脚本,如果模式空间不是空的副作用.
  • 仅当最后两行位于模式空间中时,才会评估替换命令.