-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathpost_analysis.py
executable file
·118 lines (112 loc) · 3.83 KB
/
post_analysis.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
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
#! /usr/bin/env python
import time
from argparse import ArgumentParser
import datetime
import fnmatch
import os
import sys
import glob
# check for number
def isnumber(s):
try:
float(s)
return True
except ValueError:
return False
# parse input
parser = ArgumentParser( description = "script for post analysis stuff" )
parser.add_argument( "-a", "--analysis",
help = "Name of analysis" )
parser.add_argument( "-l", "--logfile",
help = "Name of analysis log file" )
parser.add_argument( "-s", "--starttime",
help = "start time (in datetime format) of analysis ")
args = parser.parse_args()
analysis = args.analysis
starttime = args.starttime
logfile = args.logfile
# update the analysis log file (cost if in slurm)
# strip of any leading/trailing quotes
starttime = starttime.replace("_", " ")
# end time (utc)
tFmt = "%a, %d %b %Y %I:%M:%S %p"
endtime = datetime.datetime.utcnow().strftime(tFmt)
deltaTime = (datetime.datetime.strptime(endtime, tFmt) -
datetime.datetime.strptime(starttime, tFmt)).total_seconds()
td_hrs = deltaTime/60./60.
# append to log file
with open(logfile, "a") as afile:
afile.write(analysis + " end time: " + endtime + "\n")
afile.write(analysis + " elapse time(hrs): " + str(td_hrs) + "\n")
# get cost (for batch and slurm)
totCost = 0.0;
for file in os.listdir('.'):
if file.endswith(".log"):
with open(file) as thefile:
for line in thefile:
if line.startswith(">>> Info") and line.lower().find("cost"):
ll = line.split("$")
if len(ll) == 2:
if isnumber(ll[1]):
totCost += float(ll[1])
if totCost != 0.0:
with open(logfile, "a") as afile:
afile.write(analysis + " total estimated cost: $" + str(round(totCost,2)) + "\n")
# check for any errors in the log and resume files
foundErr = False
fileError = []
rfiles = glob.glob("./resume/resume*")
if len(rfiles):
for file in rfiles:
with open(file) as f:
if ">>> Error" in f.read():
fileError.append(file)
foundErr = True;
break;
ofiles = glob.glob("*.o*")
if len(ofiles):
for file in ofiles:
with open(file) as f:
if "Error" in f.read():
fileError.append(file)
foundErr = True;
break;
lfiles = glob.glob("*.log")
if len(lfiles):
for file in lfiles:
with open(file) as f:
if "Error" in f.read():
fileError.append(file)
foundErr = True;
break;
ffiles = glob.glob("fail*")
if len(ffiles):
fileError.append(",".join(ffiles))
foundErr = True;
if foundErr:
emsg = "post_analysis found some potential errors. See the files: " + str(fileError)
print(">>> Warning: " + emsg)
# append to log file
with open(logfile, "a") as afile:
afile.write(">>> Warning: " + emsg + "\n")
# cleanup
errcnt = 0
for file in os.listdir('.'):
try:
if fnmatch.fnmatch(file, '*.log') or fnmatch.fnmatch(file,'*.trace') or \
fnmatch.fnmatch(file, '*.o*') or fnmatch.fnmatch(file,'*.po*'):
os.rename('./'+file,'./log/'+file)
elif fnmatch.fnmatch(file, '*report.html') or fnmatch.fnmatch(file,'*.params') or \
fnmatch.fnmatch(file, '*report.Rmd'):
os.rename('./'+file,'./report/'+file)
elif fnmatch.fnmatch(file, '*.pdf'):
os.rename('./'+file,'./plots/'+file)
else:
continue
except Exception as e:
print('>>> Error moving/deleting file ' + file + " (" + str(e) + ")")
errcnt += 1
continue
if errcnt:
print(">>> Post_analysis encountered " + str(errcnt) + " errors.")
sys.exit(2)