时间:2020-11-25 12:02:32 | 栏目: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)