Python中的坑实例分析

发布时间:2022-02-21 15:22:12 作者:iii
来源:亿速云 阅读:99

今天小编给大家分享一下Python中的坑实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

坑从何来

最初是想要为自己的一个命令行小工具增加一个进度显示功能,于是用了threading模块来实现多线程,一个线程用于执行实际的逻辑,另一个线程用于打印当前进度。

根据我们多年使用命令行的经验,一般打印进度都是在行内打印,而 Python 的print则会默认在结尾打印一个换行符,这就十分不美了。

不过好在,print也提供了接口来改变打印的末尾字符,通过指定printend参数,即可改变print的打印结果。

所以我就哼哧哼哧地开干了,把打印进度的print("#")调用改为print("#", end="")

类似这样:

import time
import threading


def print_sharp():
    while True:
        time.sleep(0.5)
        print("#", end="")




t1 = threading.Thread(target=print_sharp)
t1.setDaemon(True)
t1.start()


time.sleep(5)

哪成想,这么一改却出了大问题:进度没法实时打印了。

也就是说,本来应该在程序执行期间,挨个打印出来的#号不再是听话的、可爱的#号了,而是在整个程序执行完成之后一次性输出到控制台中。

它长大了,也变丑了

那我要你有何用?

啥问题呢?

一开始阿酱以为是多线程出了问题,傻乎乎地到处找资料来“佐证”自己的各种猜测——事后想来实在太傻了,以至于现在说起还是会哈哈哈

这件事给我们的教训就是:千万不要自以为是,而应踏踏实实地解决问题,虚心对待每个细节

实际上,之所以我们看不到实时的输出,就是因为我们改变了print的结尾字符。

为了尽量减少I/O操作, Python 存在一个这样的机制:尽量将输出字符缓存起来,当遇到字符串结束、换行符或强制刷新缓冲区时,才会一次性将缓冲区的内容输出到相应的流中。

——而我们改掉的地方,就是把print默认的换行符去掉了,所以原本每一个print都会触发一次缓冲区刷新,变成了现在一直触发不了缓冲区刷新,直到程序结束触发一次。

好嘛,知道了啥问题,我们又吭哧吭哧找资料,听说sys.stdout.flush可以强制触发标准输出缓冲区的刷新,于是在print后面,紧跟着又加上了sys.stdout.flush()

这些可都是知识点,快记下来记下来,要考的

让我们查看print的官方文档,其原型为:

print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)

根据其下的描述, Python 中print的输出是否进行缓冲,取决于两个参数:fileflush

file的类型有的需要缓冲,比如sys.stdout;而有的则不需要缓冲,比如sys.stderr

对于flush参数,当其值为False(默认)时,是否缓冲依赖file;而当其值为True时,则会强制刷新缓冲区。

我们把示例调用中的print调用修改一下:

import sys
import time
import threading




def print_sharp():
    while True:
        time.sleep(0.5)
        print("#", end="", flush=True)




t1 = threading.Thread(target=print_sharp)
t1.setDaemon(True)
t1.start()


time.sleep(5)

同样可以实现进度的实时打印。

此外,还有一种方法,在调用程序时增加一个-u选项,也可以实现缓冲区的实时刷新:

$ python -u no_flush.py

当然这种方法就不太推荐了,毕竟不能对程序的使用者作任何预设。

以上就是“Python中的坑实例分析”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

推荐阅读:
  1. python中readline的“坑”
  2. python字典fromkeys()方法中的坑

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

python

上一篇:如何看Python的安装路径

下一篇:python中如何用OpenCv实现绘图功能

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》