任务要求
用户需求是每隔一秒钟输出一次当前系统时间,并重复五次后自动终止。
任务分析
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"):将当前时间写入文件,并在末尾添加换行符。