-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakeStat.py
60 lines (49 loc) · 1.52 KB
/
MakeStat.py
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
#!/usr/bin/python
import ast
import sys
import os
import re
import glob
import string
import gettor.config
def makestats(filename, configPackages):
# Initialize package counter
packageCounter = { 'None': 0}
for k in configPackages.keys():
packageCounter[k] = 0
try:
logFile = open(filename, 'r')
except:
print >>sys.stderr, "Couldn't open logfile %s" % filename
sys.exit(1)
readData = logFile.read().split('\n')
for line in readData:
matchStr = "([0-9]{4}-[0-9]{2}-[0-9]{2}).*({'.*'}).*"
match = re.match(matchStr, line, re.DOTALL)
if match:
dateInfo = match.group(1)
reqInfo = ast.literal_eval(match.group(2))
package = reqInfo['package']
if package is not None:
packageCounter[package] += 1
else:
packageCounter['None'] += 1
logFile.close()
return dateInfo, packageCounter
def printStatsStdout(daystr, stats):
print daystr + " -",
for pack in sorted(stats.iterkeys()):
packstr = "%s:%s" % (pack, stats[pack])
print packstr,
print ""
def main():
stats = {}
config = gettor.config.Config()
logDir = os.path.join(config.BASEDIR, "log")
logFilePattern = os.path.join(logDir, config.LOGFILE + "*.log")
fileList = glob.glob(logFilePattern)
for f in fileList:
dateInfo, stats = makestats(f, config.PACKAGES)
printStatsStdout(dateInfo, stats)
if __name__ == "__main__":
main()