码迷,mamicode.com
首页 > 编程语言 > 详细

【Python】输出程序执行的百分比

时间:2015-08-21 13:44:35      阅读:227      评论:0      收藏:0      [点我收藏+]

标签:运行百分比   python   输出   换行符   优化   

对于一些大型的Python程序,我们需要在命令行输出其百分比,显得更加友好,以免被人误会程序陷入死循环、假死的窗体。

关键是利用到不换行的输出符\r,\r的输出,将直接覆盖掉此行的内容。

比如如下的程序,是一个i从0自加的十万的过程,即使对于现在高性能的CPU也是需要几秒的时间的,我们要输出其执行时候的百分比,可以在引入sys这个包之后,利用到sys.stdout.write输出,避免原生态的print自带的\n影响大局。同时要控制百分比的小数位为4。程序执行的百分比恰好为i当前的值除以值为十万的total。

#-*-coding:utf-8-*-
import sys;
total=100000
for i in range(0,total):
    percent=float(i)*100/float(total)
    sys.stdout.write("%.4f"%percent);
    sys.stdout.write("%\r");
    sys.stdout.flush();
    
sys.stdout.write("100%!finish!\r");
sys.stdout.flush();

程序运行结果如下:

技术分享

但是,这里i每自增一次就要求当前的运行的百分比,把原本100000次的浮点运算徒然增加到二十万次,同时要刷新100000次的屏幕,非常不合理,因此对于程序,可以做如下的改进,运行百分比仅保留2位小数,同时i每累积100才进行百分比输出,程序修改之后如下:

#-*-coding:utf-8-*-
import sys;
total=100000
for i in range(0,total):
    if i%100==0:
        percent=float(i)*100/float(total)
        sys.stdout.write("%.2f"%percent);
        sys.stdout.write("%\r");
        sys.stdout.flush();
    
sys.stdout.write("100%!finish!\r");
sys.stdout.flush();

从求运行百分比的100000次的浮点运算改为100000次的条件运算,同时仅要刷新屏幕1000次,程序的运行耗时将大大减少。

同时,这里值得注意的是,Eclipse中的Pydev中的控制台,对于\r依然是处理成换行符,使得输出变成如下的样子,这里没有办法了!

技术分享

版权声明:本文为博主原创文章,未经博主允许不得转载。

【Python】输出程序执行的百分比

标签:运行百分比   python   输出   换行符   优化   

原文地址:http://blog.csdn.net/yongh701/article/details/47831561

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!