小编Ber*_*Dom的帖子

使用 awk (GNU) 命令回溯

假设您的一个数据文件返回您所有的读数。清除所有杂乱后;你得到的总是 3 列:

-ERROR -1.57 -2.02 
-2.10 -0.57 ERROR
-4.70 ERROR -0.52 
-2.20 ERROR -0.02 
-2.20 -0.07 ERROR
Run Code Online (Sandbox Code Playgroud)

我知道ERROR这是唯一的错误消息,并且对于任何数据都是随机发生的,因此,它是唯一不是数字的值。

挑战

如何用最后一次成功的读数替换任何无效的读数?我试过了

awk -F' ' ' {if (isNumber $1){ replace with previous $1}}' < log.data
Run Code Online (Sandbox Code Playgroud)

但是您首先如何参考之前的阅读内容呢?

预期输出:

 0 -1.57 -2.02 
-2.10 -0.57 -2.02
-4.70 -0.57 -0.52 
-2.20 -0.57 -0.02 
-2.20 -0.07 -0.02
Run Code Online (Sandbox Code Playgroud)

bash awk

3
推荐指数
1
解决办法
96
查看次数

标签 统计

awk ×1

bash ×1