Python实现定时输出系统时间

Python实现定时输出系统时间

编码文章call10242025-03-08 12:00:4151A+A-

任务要求

用户需求是每隔一秒钟输出一次当前系统时间,并重复五次后自动终止。

任务分析

1.时间获取:使用time.strftime()或datetime.datetime.now()获取格式化时间。

2.格式化输出:将时间格式化为易于阅读的字符串形式。

3.定时暂停:通过time.sleep(1)实现1秒间隔。

4.循环控制:采用计数变量控制执行次数。

任务实现

方法1:基础for循环

import time
for i in range(5):
current_time = time.strftime(
"%Y-%m-%d %H:%M:%S", time.localtime())
print(f"当前时间:{current_time}")
time.sleep(
1)

说明:

  • range(5)控制循环次数
  • strftime格式化时间输出
  • sleep实现1秒延迟

方法2:while循环计数

import time
count =
0
while count < 5:
current_time = time.strftime(
"%Y-%m-%d %H:%M:%S", time.localtime())
print(f"当前时间:{current_time}")
count +=
1
time.sleep(1)

说明:

  • time.ctime()直接返回可读时间字符串
  • 计数器count控制循环终止条件

方法3:datetime模块实现

from datetime import datetime
import time
for n in range(1, 6):
now = datetime.now().strftime(
"%Y-%m-%d %H:%M:%S")
print(f"当前时间:{now}")
time.sleep(
1)

说明:datetime.now()获取高精度时间。

方法4:生成器优化

import time
def timer_gen(max_times):
for i in range(max_times):
yield time.strftime("%Y-%m-%d %H:%M:%S")
time.sleep(
1)
for idx, t in enumerate(timer_gen(5), 1):
print(f"当前时间:{t}")

说明:

  • 使用生成器分离时间生成逻辑
  • enumerate自动生成序号
  • 适合需要复用定时器的场景

方法5:面向对象封装

import time
class TimeReporter:
def __init__(self, interval=1, max_times=5):
self.interval = interval
self.max_times = max_times
def run(self):
for i in range(self.max_times):
print(f"当前时间:{time.strftime("%Y-%m-%d %H:%M:%S")}")
time.sleep(
self.interval)
TimeReporter().run()

说明:

  • 通过类封装提高扩展性
  • 可自定义间隔时间和最大次数
  • 符合大型项目的模块化设计需求

运行结果

当前时间:2025-02-13 21:26:26

当前时间:2025-02-13 21:26:27

当前时间:2025-02-13 21:26:28

当前时间:2025-02-13 21:26:29

当前时间:2025-02-13 21:26:30

进程已结束,退出代码为 0

说明:第一行输出后停留1秒后再输出第二行。

代码说明

import time:用于控制程序的暂停时间。

from datetime import datetime:用于获取当前系统时间和格式化输出。

for i in range(5):循环五次,控制输出次数。

datetime.now().strftime("%Y-%m-%d %H:%M:%S"):获取当前时间并格式化为YYYY-MM-DD HH:MM:SS的形式。

time.sleep(1):让程序暂停一秒钟后再继续执行。

try-except块用于捕捉KeyboardInterrupt异常(当用户按下Ctrl+C时触发),并友好地提示程序已终止。

扩展功能

将每次输出的时间记录到文件中,可以添加文件写入功能。

任务实现

import time
from datetime import datetime
try:
with open("time_log.txt", "a") as file:
for _ in range(5):
current_time = datetime.now().strftime(
"%Y-%m-%d %H:%M:%S")
print(f"当前时间:{current_time}")
file.write(
f"{current_time}\n")
time.sleep(
1)
except KeyboardInterrupt:
print("\n程序已由用户终止。")

运行结果

当前时间:2025-02-13 21:26:26

当前时间:2025-02-13 21:26:27

当前时间:2025-02-13 21:26:28

当前时间:2025-02-13 21:26:29

当前时间:2025-02-13 21:26:30

进程已结束,退出代码为 0

说明:第一行输出后停留1秒后再输出第二行。并将在python源文件目录下创建了一个“time_log.txt”文件保存当前时间

代码说明

with open("time_log.txt", "a") as file::打开一个名为time_log.txt的文件,以追加模式准备写入数据,并确保文件操作完成后文件会被自动关闭。

file.write(f"{current_time}\n"):将当前时间写入文件,并在末尾添加换行符。

点击这里复制本文地址 以上内容由文彬编程网整理呈现,请务必在转载分享时注明本文地址!如对内容有疑问,请联系我们,谢谢!
qrcode

文彬编程网 © All Rights Reserved.  蜀ICP备2024111239号-4