13人参与 • 2026-01-27 • Python
现代人注意力分散已成为普遍问题,手机通知、社交媒体、多任务处理不断打断我们的工作节奏。番茄工作法(pomodoro technique)通过25分钟专注+5分钟休息的循环,帮助我们建立规律的工作节奏。本文将用python的tkinter库实现一个可视化番茄钟,包含倒计时显示、开始/暂停/重置功能,以及工作/休息状态切换。这个项目适合python初学者理解gui编程基础,也能作为日常效率工具使用。
确保已安装python 3.x版本(推荐3.6+),tkinter是python标准库的一部分,无需额外安装。可以通过以下命令验证:
import tkinter as tk print(tk.tkversion) # 应输出版本号
创建单个python文件即可完成基础功能,建议文件结构:
pomodoro_timer/
└── pomodoro.py # 主程序文件
class pomodorotimer:
def __init__(self):
self.work_duration = 25 * 60 # 25分钟转秒
self.break_duration = 5 * 60 # 5分钟转秒
self.remaining_time = self.work_duration
self.is_working = true
self.is_running = false
import tkinter as tk
from tkinter import messagebox
class pomodoroapp:
def __init__(self, root):
self.root = root
self.root.title("番茄钟专注工具")
self.root.geometry("400x500")
self.root.resizable(false, false)
# 初始化计时器
self.timer = pomodorotimer()
# 创建界面组件
self.create_widgets()
使用label组件显示大字体时间,设置合适的字体和颜色:
def create_widgets(self):
# 时间显示
self.time_label = tk.label(
self.root,
text="25:00",
font=("helvetica", 72, "bold"),
fg="#ff4757" if self.timer.is_working else "#2ed573"
)
self.time_label.pack(pady=50)
# 状态标签
self.status_label = tk.label(
self.root,
text="工作模式",
font=("helvetica", 16),
fg="#2f3542"
)
self.status_label.pack()
使用frame容器组织按钮,添加开始/暂停和重置功能:
# 按钮容器
button_frame = tk.frame(self.root)
button_frame.pack(pady=30)
# 开始/暂停按钮
self.start_button = tk.button(
button_frame,
text="开始",
command=self.toggle_timer,
font=("helvetica", 14),
bg="#2ed573",
fg="white",
width=10
)
self.start_button.pack(side=tk.left, padx=10)
# 重置按钮
self.reset_button = tk.button(
button_frame,
text="重置",
command=self.reset_timer,
font=("helvetica", 14),
bg="#ff6b81",
fg="white",
width=10
)
self.reset_button.pack(side=tk.left, padx=10)
将秒数转换为"分:秒"格式:
def format_time(self, seconds):
mins = seconds // 60
secs = seconds % 60
return f"{mins:02d}:{secs:02d}"
使用after()方法实现非阻塞倒计时:
def update_timer(self):
if self.timer.is_running:
self.timer.remaining_time -= 1
self.time_label.config(
text=self.format_time(self.timer.remaining_time),
fg="#ff4757" if self.timer.is_working else "#2ed573"
)
# 时间到切换状态
if self.timer.remaining_time <= 0:
self.switch_mode()
return
self.root.after(1000, self.update_timer)
处理工作/休息模式转换:
def switch_mode(self):
if self.timer.is_working:
self.timer.is_working = false
self.timer.remaining_time = self.timer.break_duration
self.status_label.config(text="休息时间")
# 播放提示音(可选)
try:
import winsound
winsound.beep(1000, 500)
except:
pass
else:
self.timer.is_working = true
self.timer.remaining_time = self.timer.work_duration
self.status_label.config(text="工作模式")
# 询问是否继续下一轮
if messagebox.askyesno("继续", "本轮已完成,开始下一轮吗?"):
pass
else:
self.reset_timer()
return
self.start_button.config(text="开始")
self.timer.is_running = false
实现开始/暂停和重置功能:
def toggle_timer(self):
self.timer.is_running = not self.timer.is_running
btn_text = "暂停" if self.timer.is_running else "开始"
self.start_button.config(text=btn_text)
def reset_timer(self):
self.timer.is_running = false
self.start_button.config(text="开始")
if self.timer.is_working:
self.timer.remaining_time = self.timer.work_duration
else:
self.timer.remaining_time = self.timer.break_duration
self.time_label.config(
text=self.format_time(self.timer.remaining_time),
fg="#ff4757" if self.timer.is_working else "#2ed573"
)
将所有部分组合成完整应用:
import tkinter as tk
from tkinter import messagebox
class pomodorotimer:
def __init__(self):
self.work_duration = 25 * 60
self.break_duration = 5 * 60
self.remaining_time = self.work_duration
self.is_working = true
self.is_running = false
class pomodoroapp:
def __init__(self, root):
self.root = root
self.root.title("番茄钟专注工具")
self.root.geometry("400x500")
self.root.resizable(false, false)
self.timer = pomodorotimer()
self.create_widgets()
self.update_timer() # 启动更新循环
def create_widgets(self):
# 时间显示
self.time_label = tk.label(
self.root,
text="25:00",
font=("helvetica", 72, "bold"),
fg="#ff4757" if self.timer.is_working else "#2ed573"
)
self.time_label.pack(pady=50)
# 状态标签
self.status_label = tk.label(
self.root,
text="工作模式",
font=("helvetica", 16),
fg="#2f3542"
)
self.status_label.pack()
# 按钮容器
button_frame = tk.frame(self.root)
button_frame.pack(pady=30)
# 开始/暂停按钮
self.start_button = tk.button(
button_frame,
text="开始",
command=self.toggle_timer,
font=("helvetica", 14),
bg="#2ed573",
fg="white",
width=10
)
self.start_button.pack(side=tk.left, padx=10)
# 重置按钮
self.reset_button = tk.button(
button_frame,
text="重置",
command=self.reset_timer,
font=("helvetica", 14),
bg="#ff6b81",
fg="white",
width=10
)
self.reset_button.pack(side=tk.left, padx=10)
def format_time(self, seconds):
mins = seconds // 60
secs = seconds % 60
return f"{mins:02d}:{secs:02d}"
def update_timer(self):
if self.timer.is_running:
self.timer.remaining_time -= 1
self.time_label.config(
text=self.format_time(self.timer.remaining_time),
fg="#ff4757" if self.timer.is_working else "#2ed573"
)
if self.timer.remaining_time <= 0:
self.switch_mode()
return
self.root.after(1000, self.update_timer)
def switch_mode(self):
if self.timer.is_working:
self.timer.is_working = false
self.timer.remaining_time = self.timer.break_duration
self.status_label.config(text="休息时间")
try:
import winsound
winsound.beep(1000, 500)
except:
pass
else:
self.timer.is_working = true
self.timer.remaining_time = self.timer.work_duration
self.status_label.config(text="工作模式")
if not messagebox.askyesno("继续", "本轮已完成,开始下一轮吗?"):
self.reset_timer()
return
self.start_button.config(text="开始")
self.timer.is_running = false
def toggle_timer(self):
self.timer.is_running = not self.timer.is_running
btn_text = "暂停" if self.timer.is_running else "开始"
self.start_button.config(text=btn_text)
def reset_timer(self):
self.timer.is_running = false
self.start_button.config(text="开始")
if self.timer.is_working:
self.timer.remaining_time = self.timer.work_duration
else:
self.timer.remaining_time = self.timer.break_duration
self.time_label.config(
text=self.format_time(self.timer.remaining_time),
fg="#ff4757" if self.timer.is_working else "#2ed573"
)
if __name__ == "__main__":
root = tk.tk()
app = pomodoroapp(root)
root.mainloop()
使用configparser模块保存用户自定义的工作/休息时长:
import configparser
config = configparser.configparser()
config['default'] = {
'work_duration': '25',
'break_duration': '5',
'long_break_duration': '15',
'cycles_before_long_break': '4'
}
with open('settings.ini', 'w') as f:
config.write(f)
添加完成轮次统计和专注时间累计:
class pomodorotimer:
def __init__(self):
# ...原有初始化...
self.completed_cycles = 0
self.total_focus_time = 0
集成简单任务列表,与番茄钟结合使用:
class taskmanager:
def __init__(self):
self.tasks = []
def add_task(self, text):
self.tasks.append({"text": text, "completed": false})
使用plyer库实现跨平台通知:
from plyer import notification
def show_notification(title, message):
notification.notify(
title=title,
message=message,
timeout=10
)
设置resizable(false, false)防止窗口被拉伸影响布局:
root = tk.tk() root.resizable(false, false) # 禁止调整宽高
确保after()方法在所有条件下都会被调用,避免递归中断:
def update_timer(self):
# ...计时逻辑...
self.root.after(1000, self.update_timer) # 确保每次都被调用
使用跨平台方案替代winsound:
import os
import platform
def play_sound():
system = platform.system()
if system == "windows":
try:
import winsound
winsound.beep(1000, 500)
except:
pass
elif system == "darwin": # macos
os.system("afplay /system/library/sounds/ping.aiff")
else: # linux
os.system("paplay /usr/share/sounds/freedesktop/stereo/bell.oga")
这个简易番茄钟实现了核心功能:可视化倒计时、状态切换、操作控制。通过这个项目,我们学习了:
后续可以扩展为更完整的效率工具,加入:
建议初学者尝试自己实现这些扩展功能,逐步提升编程能力。记住,好的工具应该简单易用,过度复杂的设计反而会降低效率,保持核心功能的简洁性才是关键。
到此这篇关于python使用tkinter编写一个高效倒计时番茄钟的文章就介绍到这了,更多相关python倒计时番茄钟内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论