我有一个看起来像这样的数据框:

ERR843978.19884 13 51 51
ERR843978.2880 10 49 51
ERR843978.10002 7 48 55
ERR843978.1158 8 45 54
ERR843978.4671 14 62 60
ERR843978.83 15 56 70
ERR843978.9406 8 56 39
ERR843978.8383 12 59 43
ERR843978.8916 6 51 42

我希望对所有行都这样做:
column2/(column3*column4)

然后将输出打印到新文件中。

我已经编写了一个可以执行此操作的bash脚本,但是它有点慢,所以我正在寻找一种更有效的解决方案(也许使用awk吗?)。

这是我的代码
while read line
do
        out0=$(awk '{print $1}' <<< $line)
        out1=$(awk '{print $2}' <<< $line)
        out2=$(awk '{print $3}' <<< $line)
        out3=$(awk '{print $4}' <<< $line)
        out4=`echo "scale=5; ($out1 / ($out2 * $out3))"|bc -l`
        echo "$out0;$out4"
done < $file

最佳答案

是的, awk 在这里非常有效:

awk '{ print $2/($3 * $4) }' file > newfile

关于bash - bash中的多个/除列,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/49571711/

10-12 17:52