python实现cli命令行的进度条光标滚动显示效果

2020-12-15  本文已影响0人  iamdev

python如何实现cli命令行的光标滚动效果?我们在制作cli工具的时候,会遇到如果比较长时间执行的任务,可能需要类似progress进度的功能,这样用户使用的时候会比较友好。这篇文章主要是使python来实现这样的效果。

主要借助Thread lib,在执行长时间运行任务的时候,新建一个Thread在后台持续往控制台输出光标。

在使用Thread的时候需要注意意外退出情况下停止Thread,将Thread的daemon设置为True,这样子在退出python进程的情况下同时退出Thread子进程

代码运行效果如图所示:


progress2.gif

下面直接上代码,使用的都是python标准库,最后有实际使用的例子代码:

import sys
import time
from threading import Thread


class ProgressThread(Thread):
    def __init__(self):
        super(ProgressThread, self).__init__()
        self.is_stop = False
        self.cursor_index = 0
        self.cursor_str = '|/-\\'
        self.now = None
        self.info = ""

    def set_progress_info(self, info):
        self.info = info

    def get_progress_text(self):
        cursor = self.cursor_str[self.cursor_index]
        self.cursor_index = self.cursor_index + 1
        if self.cursor_index == len(self.cursor_str):
            self.cursor_index = 0
        time_second = str(int(time.time() - self.now))
        progress_text = self.info + " " + time_second + "s " + cursor
        return progress_text

    def stop_progress(self):
        self.is_stop = True
        time.sleep(0.6)

    def run(self):
        self.now = time.time()
        while True:
            if not self.is_stop:
                progress_text = self.get_progress_text()
                sys.stdout.write(progress_text)
                sys.stdout.flush()
                time.sleep(0.4)
                sys.stdout.write('\r')
            else:
                return


class Progress:

    def __init__(self):
        self.current_thread = None
        pass

    def start_progress(self, progress_info):
        if self.current_thread is not None:
            self.current_thread.stop_progress()
        self.current_thread = ProgressThread()
        self.current_thread.daemon = True
        self.current_thread.set_progress_info(progress_info)
        self.current_thread.start()

    def stop_progress(self):
        if self.current_thread is not None:
            self.current_thread.stop_progress()
        self.current_thread = None

    def show_progress(self, info):
        self.current_thread.set_progress_info(info)


if __name__ == '__main__':
    progress = Progress()
    progress.start_progress("开始上传文件")
    for i in range(10):
        time.sleep(0.5)
        progress.show_progress("文件上传中")
    progress.stop_progress()

上一篇下一篇

猜你喜欢

热点阅读