dieser Abtastwerteingang Gegeben:Berechnung Prozentsatz in beliebiger Anzahl von Spalten
ID Sample1 Sample2 Sample3 One 10 0 5 Two 3 6 8 Three 3 4 7
Ich brauchte diese Ausgabe mit AWK zu produzieren:
ID Sample1 Sample2 Sample3 One 62.50 0.00 25.00 Two 18.75 60.00 40.00 Three 18.75 40.00 35.00
Dies ist, wie ich es gelöst:
function percent(value, total) {
return sprintf("%.2f", 100 * value/total)
}
{
label[NR] = $1
for (i = 2; i <= NF; ++i) {
sum[i] += col[i][NR] = $i
}
}
END {
title = label[1]
for (i = 2; i <= length(col) + 1; ++i) {
title = title "\t" col[i][1]
}
print title
for (j = 2; j <= NR; ++j) {
line = label[j]
for (i = 2; i <= length(col) + 1; ++i) {
line = line "\t" percent(col[i][j], sum[i])
}
print line
}
}
Dies funktioniert gut in GNU AWK (awk
in Linux, gawk
in BSD), aber nicht in BSD AWK, wo ich diesen Fehler:
$ awk -f script.awk sample.txt awk: syntax error at source line 7 source file script.awk context is sum[i] += >>> col[i][ <<< awk: illegal statement at source line 7 source file script.awk awk: illegal statement at source line 7 source file script.awk
Es scheint, das Problem mit dem mehrdimensionalen Arrays ist. Ich möchte dieses Skript auch in BSD AWK arbeiten, , so dass es tragbarer ist.
Gibt es eine Möglichkeit, dies zu ändern, damit es in BSD AWK funktioniert?
Einfache Antwort - versuchen nawk. Es sollte Teil der BSD-Installation sein. Einige Versionen von awk sind wirklich alt. –