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)
有什么想法吗?
使用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具有重新启动脚本,如果模式空间不是空的副作用.