-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprogress.py
51 lines (45 loc) · 1.81 KB
/
progress.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
import os
from time import time
import datetime
def printProgressBar(iteration, total, prefix='Progress', suffix='', decimals=1, length=100, fill='█'):
"""
Print iterations progress
Call in a loop to create terminal progress bar
@params:
iteration - Required : current iteration (Int)
total - Required : total iterations (Int)
prefix - Optional : prefix string (Str)
suffix - Optional : suffix string (Str)
decimals - Optional : positive number of decimals in percent complete (Int)
length - Optional : character length of bar (Int)
fill - Optional : bar fill character (Str)
"""
percent = ("{0:." + str(decimals) + "f}").format(100 *
(iteration / float(total)))
filledLength = int(length * iteration // total)
bar = fill * filledLength + '-' * (length - filledLength)
print('\r%s |%s| %s%% %s' % (prefix, bar, percent, suffix), end='\r')
# Print New Line on Complete
if iteration == total:
print()
def printTiming(start):
"""
timer function, just to check the performance
"""
end = time()
duration = end - start
if duration < 60:
print("Total Timing: " + str(round(duration, 2)) + "s.", end='\n')
else:
mins = int(duration / 60)
secs = round(duration % 60, 2)
if mins < 60:
print("Total Timing: " + str(mins) +
"m " + str(secs) + "s.", end='\n')
else:
hours = int(duration / 3600)
mins = mins % 60
print("Total Timing: " + str(hours) + "h " +
str(mins) + "m " + str(secs) + "s.", end='\n')
def printDate(prefix):
print(prefix + datetime.datetime.now().strftime("%Y-%m-%d %H:%M"), end='\n')