-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathplot.sh
executable file
·86 lines (74 loc) · 1.51 KB
/
plot.sh
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#!/bin/sh
USER_STATS=$(mktemp)
SUM_STATS=$(mktemp)
# Invert columns and rows
#
# Users 2015-12-08 2015-12-09 2015-12-10
# john 10 15 20
# sally 15 28 40
# zach 8 10 12
#
# |
# v
#
# Users john sally zach
# 2015-12-08 10 15 8
# 2015-12-09 15 28 10
# 2015-12-10 20 40 12
invert_table() {
awk '
{
for (i=1; i<=NF; i++) {
a[NR,i] = $i
}
}
NF>p { p = NF }
END {
for(j=1; j<=p; j++) {
str=a[1,j]
for(i=2; i<=NR; i++){
str=str"\t"a[i,j];
}
print str
}
}' $@
}
# Sum each column to get totals for each day and construct a TSV with just the
# totals in it
# Add the date headers to $SUM_STATS
head -n 1 slack_stats.tsv | cut -f2- >> $SUM_STATS
# Calculate the totals for each date and add them to $SUM_STATS
sed -e 's/\t\t/\t0\t/g' -e 's/\t\t/\t0\t/g' slack_stats.tsv |
tail -n+2 |
cut -f 2- |
awk '
{
for (i=1; i<=NF; i++) {
sum[i] += $i
}
}
END {
for (i in sum) {
print sum[i]
}
}' |
paste -sd'\t' >> $SUM_STATS
# Invert the $SUM_STATS table
tmp_sum=$(mktemp)
invert_table $SUM_STATS > $tmp_sum
mv $tmp_sum $SUM_STATS
invert_table slack_stats.tsv > $USER_STATS
gnuplot --persist <<EOF
set xdata time
set timefmt '%Y-%m-%dT%H:%M%SZ'
set nokey
set multiplot layout 2, 1 title "Slack Usage Statistics" font ",14"
set tmargin 4
set title "All Time Messages"
plot '$SUM_STATS' using 1:2 with lines
set title "User Messages"
nc = "`awk 'NR == 1 { print NF; exit }' $USER_STATS`"
plot for [i=2:nc] '$USER_STATS' using 1:i with lines
EOF
rm $USER_STATS
rm $SUM_STATS