我在我的程序中使用 time.sleep(10)。运行程序时可以在 shell 中显示倒计时吗?
>>>run_my_program()
tasks done, now sleeping for 10 seconds
然后我想让它做 10,9,8,7....
这可能吗?
我在我的程序中使用 time.sleep(10)。运行程序时可以在 shell 中显示倒计时吗?
>>>run_my_program()
tasks done, now sleeping for 10 seconds
然后我想让它做 10,9,8,7....
这可能吗?
你总是可以的
#do some stuff
print 'tasks done, now sleeping for 10 seconds'
for i in xrange(10,0,-1):
time.sleep(1)
print i
这个片段有一个有点烦人的特性,每个数字都被打印在一个换行符上。为避免这种情况,您可以
import sys
import time
for i in xrange(10,0,-1):
sys.stdout.write(str(i)+' ')
sys.stdout.flush()
time.sleep(1)
这是在 Python 3.x 的控制台中显示计时器的最佳方式:
import time
import sys
for remaining in range(10, 0, -1):
sys.stdout.write("\r")
sys.stdout.write("{:2d} seconds remaining.".format(remaining))
sys.stdout.flush()
time.sleep(1)
sys.stdout.write("\rComplete! \n")
这会覆盖每个周期的前一行。
从控制台清除最后一个数字的简单解决方案:
import time
for i in range(10,0,-1):
print(f"{i}", end="\r", flush=True)
time.sleep(1)
默认情况下, print 函数设置end="\n"
这意味着后续的 print 调用将打印在新行上。您可以将其更改为end="\r"
在每次调用后替换输出。(回车“\r”如何在 python 中工作)。
此外,使用flush
意味着您不必担心缓冲问题。(print() 的作用是flush
什么?)
这是它的外观:
您可以执行倒计时功能,例如:
import sys
import time
def countdown(t, step=1, msg='sleeping'): # in seconds
pad_str = ' ' * len('%d' % step)
for i in range(t, 0, -step):
print '%s for the next %d seconds %s\r' % (msg, i, pad_str),
sys.stdout.flush()
time.sleep(step)
print 'Done %s for %d seconds! %s' % (msg, t, pad_str)
回车\r
和逗号,
将保持打印在同一行(避免每个倒计时值一行)
随着秒数的减少,pad_str 将确保最后一行被空格覆盖,而不是在输出缩短时留下最后一个字符。
最后的打印用 done 消息覆盖最后的状态消息并增加输出行,因此有延迟的证据。
这是我做的一个:
import time
a = input("How long is the countdown?")
while a != 0:
print a
time.sleep(1)
a = a-1
最后,如果您和其他人可以设置警报或其他任何东西。
这是我在第一堂 python 课程中学到的东西,我们用 ["/","-","|","\","|"] 玩,但原理是一样的:
import time
for i in reversed(range(0, 10)):
time.sleep(1)
print "%s\r" %i,
当然,只需编写一个循环,打印 10 减去迭代计数器,然后让它每次迭代休眠 1 秒并运行 10 次迭代。或者,更灵活:
def printer(v):
print v
def countdown_timer(duration, step=1, output_function=printer,
prompt='Waiting {duration} seconds.'):
output_function(prompt.format(duration=duration))
for i in xrange(duration/step):
output_function(duration - step * i)
time.sleep()
如果睡眠被信号中断或更晚(取决于操作系统/解释器对其他进程/线程的调度),则可能会更早返回。
为了提高多次迭代的准确性,避免大量迭代的漂移,倒计时可以与时钟锁定:
#!/usr/bin/env python
import sys
import time
for i in reversed(range(1, 1001)):
time.sleep(1 - time.time() % 1) # sleep until a whole second boundary
sys.stderr.write('\r%4d' % i)
这是亚秒级精度:
print()
_k = 0.5 # ensure k != _k first time round (as k will be integer)
print('Starting in ')
while _k > 0:
k = round(event_timestamp - time())
if k != _k:
print(f'\r{k} ', end='', flush=True)
_k = k
sleep(0.1)
print('boom')
注意 中的尾随空格f'\r{k} '
。因此,如果我们从100
to99
或10
to9
它清除第二个数字。
它也不需要import sys
.
sleep(0.0003)
如果你想要毫秒精度。
如果你不限制自己睡觉,那么(礼貌automatedtheboringstuff),pyautogui 有一个漂亮的倒计时功能:
import pyautogui
print('Starting in ', end=''); pyautogui.countdown(3)
另一种无需重新发明轮子的简单方法是使用tqdm,它会自动显示进度条:
from time import sleep
from tqdm import tqdm
for _ in tqdm(range(10)):
sleep(1)
或者,您可以根据需要修改加载栏的显示。