python运行时强制刷新缓冲区
需求
:打印一颗”*”休息1s
代码如下:
#!/usr/bin/python
#coding=utf-8
'''
暂停1s输出
'''
import time
def printStar(n):
for i in range(n):
print " * ",
time.sleep(1)
if __name__ == '__main__':
printStar(10)
输出结果(等待10s后一次性输出):
[root@miner_k test]# Python sleep.py
* * * * * * * * * *
分析原因:
在运行代码时,打印10个"*"
没有占满缓存区,所以等到程序结束时,才会一次性输出。
缓冲区的刷新方式:
1.flush()刷新缓存区
2.缓冲区满时,自动刷新
3.文件关闭或者是程序结束自动刷新。
正确代码:
#!/usr/bin/python
#coding=utf-8
'''
暂停1s输出
'''
import time
import sys
def printStar(n):
for i in range(n):
print " * ",
sys.stdout.flush()
time.sleep(1)
if __name__ == '__main__':
printStar(10)
相关文章