Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/66.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
awk对文件中匹配字符串的平均值_Awk - Fatal编程技术网

awk对文件中匹配字符串的平均值

awk对文件中匹配字符串的平均值,awk,Awk,我正在尝试使用$3中的值与awk的总和来平均匹配的$2行。我下面的尝试没有产生预期的结果。我做错了什么,但不知道是什么。谢谢:) 输入 chr7:83016288-83016376 SEMA3E 70.3 chr7:83606437-83606522 SEMA3A 78.6 chr7:83640327-83640417 SEMA3A 79.2 chr8:61693548-61693999 CHD7 83.4 chr8:61714076-61714162 CHD7 86.5 所需输出--3位小数

我正在尝试使用
$3
中的值与
awk
的总和来平均匹配的
$2
行。我下面的尝试没有产生预期的结果。我做错了什么,但不知道是什么。谢谢:)

输入

chr7:83016288-83016376 SEMA3E 70.3
chr7:83606437-83606522 SEMA3A 78.6
chr7:83640327-83640417 SEMA3A 79.2
chr8:61693548-61693999 CHD7 83.4
chr8:61714076-61714162 CHD7 86.5
所需输出--3位小数

SEMA3A 76.0
CHD7 84.9
awk尝试1

awk '{cnt[$2]++ } {sum += $3 } END { if (NR > 0) print sum / NR }' input
79.6 -- average of all lines in input
awk尝试2

awk '{cnt+=$2; num+=$3} END{print "avg="cnt/num}' input
avg=0 -- not sure what this is calculating
$ awk '{sum[$2]+=$3; count[$2]++} 
    END{for(k in sum) printf "%s %.1f\n",  k, sum[k]/count[k]}' file

CHD7 85.0
SEMA3A 78.9
SEMA3E 70.3