Newer
Older
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
import os
import re
import sys
summaryFile = '_log_summaryActors.txt'
ext = ".out"
if len(sys.argv) == 1:
sys.exit('Error: no input folder specified')
else:
folder = sys.argv[1]
def determine_output(folder,file):
outFile = open(folder + file, 'r')
print(outFile)
try:
lines = outFile.readlines()
except UnicodeDecodeError:
outFile.close()
outFile = open(folder + file, encoding = "ISO-8859-1")
lines = outFile.readlines()
counter = 1
for line in reversed(lines):
if counter > 30:
return -1
else:
if "Hours" in line:
hours = re.findall("\d+\.\d+", line)
return hours
counter += 1
try:
os.remove(folder + "/" + summaryFile)
except OSError:
pass
files = []
for file in os.listdir(folder):
if file.endswith(ext):
files.append(file)
files.sort()
total_success = []
computation_time = []
with open(folder + '/' + summaryFile, "w") as sf:
sf.write('Summarizing log files in ' + folder + '\n \n')
sf.write('Log files' + '\n')
for file in files:
value = determine_output(folder, file)
if value == -1:
sf.write("{} - Still Running or Failed\n".format(file))
else:
sf.write("{} - Success after {} hours \n".format(file, value[0]))