blob: 3e4661f795a561c44e578ff03a3d3a9c142bb2f9 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
#!/usr/bin/awk -f
### sum3.awk, print sums of numeric columns
# input: rows of integers and strings
# output: sums of numeric columns
# assumes every line has same layout
function isnum(n) {
return n ~ /^[+-]?[0-9]+$/
}
BEGIN { OFS = FS }
NR == 1 {
nfld = NF
for (i=1; i<=NF; i++)
numcol[i] = isnum($i)
}
{
for (i=1; i<=NF; i++)
if (numcol[i])
sum[i] += $i
}
END {
for (i=1; i<=nfld; i++) {
printf(numcol[i] ? sum[i] : "--")
printf(i < nfld ? OFS : ORS)
}
}
|