summaryrefslogtreecommitdiff
path: root/sum3.awk
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)
    }
}