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

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

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

aaa
bbb*
ccc*
ddd*
eee

我的输出应该是:

aaa
bbb*
ccc*
ddd
eee

有什么想法吗?

最佳答案
使用sed在单次传递中执行此操作的一般方法是使用滑动窗口,类似于GNU sed manual中描述的.

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

sed 'N; $! { P; D; }; s/.\n/\n/'

或者作为BSD sed兼容脚本:

sed 'N; $! { P; D; }; s/.\n/\
/'

输出:

aaa
bbb*
ccc*
ddd
eee

说明

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

转载注明原文:linux – 从unix中的倒数第二行删除一个字符 - 代码日志