我有一个这样的文件:
0.0451660231
0.0451660231
0.0527343825
0.3933106065
0.3970947862
0.0489502028
0.3592529595
0.3592529595
0.3592529595
0.3630371392
0.3630371392
0.3668213189
0.4008789659
0.1397705227
我想将每一行除以最大值。
我做到了
cut -f1 -d"," CVBR1_hist | sort -n | tail -1 > maximum
awk -v c=$maximum '{print $1/c}' CVBR1_hist > CVBR1_norm
我有这个错误:
awk: cmd. line:1: (FILENAME=CVBR1_hist FNR=1) fatal: division by zero attempted
我不知道如何解决。谁能帮我?
答案1
假设对文件内容进行CVBR1_hist
数字排序会生成正确的数据:
$ sort -n CVBR1_hist
0.0451660231
0.0451660231
0.0489502028
0.0527343825
0.1397705227
0.3592529595
0.3592529595
0.3592529595
0.3630371392
0.3630371392
0.3668213189
0.3933106065
0.3970947862
0.4008789659
然后我们可以使用如下命令替换将最大值存储在变量中:
maximum="$( sort -n CVBR1_hist | tail -n 1 )"
然后可以通过以下方式获得标准化值awk
:
awk -v m="$maximum" '{ print $1/m }' CVBR1_hist >CVBR1_norm
所以你唯一缺少的是在变量中正确存储最大值。
答案2
这是一个一次性 awk 解决方案,但它将内存中的所有数据存储在一个数组中。像这样运行它:awk -f thisprogram.awk < CVBR1_hist > CVBR1_norm
{
elements[NR]=$1
if ($1 > largest) {
largest = $1
}
}
END {
for(i=1; i <= NR; i++)
printf "%.10f\n", elements[i]/largest
}
答案3
awk 会给出错误,因为变量“c”被设置为等于空变量。 $maximum 尚未设置。
你应该做:
awk -v c=`cat maximum` '{print $1/c}' CVBR1_hist > CVBR1_norm
这是您的命令失败的地方。
更好的方法:不要遍历临时文件,而是将最大值存储在变量中,例如拘萨罗南达的回答。