我有一个来自脚本thescript的输出,内容如下:
202 1 0 1 0 0 0
现在我想用awk选择性地将这个数字加起来,具体取决于${SUM_MASK}的值:
SUM_MASK=1,1,0
我希望有类似的东西:
thescript | awk <SOMETHING>
其中thescript的每个数字输出乘以${SUM_MASK}中的相应数字,获得:
203
结果:
203 = 202 * 1 1 * 1 0 * 0 1 * 0 0 * 0 0 * 0 0 * 0
这与电子表格软件中的sumproduct功能类似.
下面的代码snipets可以解决这个问题,但我想避免使用进程替换:
SUM_MASK="1,0"; paste <(thescript) <(echo ${SUM_MASK} | tr ',' '\n') | awk '{ SUM += $1 * $2 } END { print SUM }'
和命名管道:
SUM_MASK="1,0"; mkfifo fA; mkfifo fB; thescript > fA & echo ${SUM_MASK} | tr ',' '\n' > fB & paste fA fB | awk '{ SUM += $1 * $2 } END { print SUM }' > result.text; rm -f fA fB
我怎么能实现这一目标?
解决方法
echo "202 1 0 1 0 0 0" | awk -v summask="1,0" ' BEGIN {split(summask,mask,/,/)} { sumproduct=0 for (i=1; i<=NF; i++) { sumproduct += $i * mask[i] } print sumproduct } '
203