我的数据框看起来像这样:
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
原文地址:https://www.jb51.cc/bash/384326.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。