gpt4 book ai didi

arrays - bash- 求行中数字的平均值

转载 作者:行者123 更新时间:2023-11-29 09:39:59 25 4
gpt4 key购买 nike

我正在尝试逐行读取文件并找出每行中数字的平均值。我收到错误:expr: non-numeric argument

我已将问题缩小到 sum=expr $sum + $i,但我不确定为什么代码不起作用。

while read -a rows
do
for i in "${rows[@]}"
do
sum=`expr $sum + $i`
total=`expr $total + 1`
done
average=`expr $sum / $total`
done < $fileName

文件看起来像这样(数字用制表符分隔):

1       1       1       1       1
9 3 4 5 5
6 7 8 9 7
3 6 8 9 1
3 4 2 1 4
6 4 4 7 7

最佳答案

通过一些小的更正,您的代码运行良好:

while read -a rows
do
total=0
sum=0
for i in "${rows[@]}"
do
sum=`expr $sum + $i`
total=`expr $total + 1`
done
average=`expr $sum / $total`
echo $average
done <filename

使用样本输入文件,产生的输出是:

1
5
7
5
2
5

请注意,答案就是答案,因为 expr 只进行整数运算。

使用 sed 对 expr 进行预处理

上面的代码可以重写为:

$ while read row; do expr '(' $(sed 's/  */ + /g' <<<"$row") ')' / $(wc -w<<<$row); done < filename
1
5
7
5
2
5

使用 bash 的内置算术能力

expr 是过时的。在现代 bash 中:

while read -a rows
do
total=0
sum=0
for i in "${rows[@]}"
do
((sum += $i))
((total++))
done
echo $((sum/total))
done <filename

使用 awk 进行浮点运算

因为 awk 进行浮点运算,所以它可以提供更准确的结果:

$ awk '{s=0; for (i=1;i<=NF;i++)s+=$i; print s/NF;}' filename
1
5.2
7.4
5.4
2.8
5.6

关于arrays - bash- 求行中数字的平均值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32917920/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com