自己实现一个进度条

在控制台打印进度,统计进度,已有时间,剩余时间,适应性还不是很好;可以自定义进度条的长度和进度的总数,两者是独立的;用户可以直接传入想显示的进度,也可以将当前进度加上一个数值;

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
import time
# 将秒转换格式化时间
def seconds_format(seconds):
m, s = divmod(seconds, 60)
h, m = divmod(m, 60)
if h == 0:
return '%02d:%02d' % (m, s)
return '%02d:%02d:%02d' % (h, m, s)
class Bar(object):
def __init__(self, total_size, title, block_size=30, signal='#'):
if total_size < block_size:
block_size = total_size
self.total_size = total_size # 总进度数
self.block_size = block_size # 进度条格子数(默认为 50)
self.process_size = min(total_size, self.block_size) # 设置进度条长度最大值
self.title = title # 进度条前的名称
self.process_now = 0 # 当前进度
self.signal = signal # 进度条内符号
self.start_time = time.time() # 起始时间
def __cost_time(self):
cost = time.time() - self.start_time
return seconds_format(cost)
# 剩余时间 = 总进度 / 当前速率 - 当前用时,当前速率 = 当前进度 / 当前用时
def __left_time(self):
time_now = (time.time() - self.start_time)
if time_now == 0:
return '-:-:-'
speed = self.process_now / time_now
left_seconds = int(self.total_size / speed - time_now)
return seconds_format(left_seconds)
# 用户直接传入当前进度,注:i从0开始
def update(self, i, add=1):
i += add
self.process_now = i
process = '\r ' + self.title + ' %d of %d %2d%% [%s%s] Cost: ' + self.__cost_time() + ' Left: ' + self.__left_time()
step = int(i / self.total_size * self.block_size)
a = self.signal * step
b = ' ' * (self.process_size - step)
c = (i / self.total_size) * 100
print(process % (i, self.total_size, c, a, b), end='')
# 当你不方便取到当前进度时,直接将当前进度+1
def update_once(self):
self.update(self.process_now)
# 当你不方便取到当前进度时,直接将当前进度 + multi
def update_multiple(self, multi):
self.update(self.process_now, add=multi)
if __name__ == '__main__':
total = 1000
bar = Bar(total, 'Progress:')
for i in range(total):
bar.update(i)
time.sleep(0.01)

progress

存在问题:

  • 在 mac 系统中\r不会讲光标退回行首,无法覆盖之前的打印信息,而是会换行
  • 无法自义定是否显示进度条的名称,CostLeft功能,以及修改这些文字
您的支持鼓励我继续创作!