百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Python实现定时输出系统时间(在python中运行下列程序输出结果是)

wptr33 2025-03-29 23:05 18 浏览

任务要求

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

任务分析

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"):将当前时间写入文件,并在末尾添加换行符。

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...