tkinter日历程序的设计

发布于:2025-03-26 ⋅ 阅读:(30) ⋅ 点赞:(0)

在这里插入图片描述

1. 程序概述

这是一个使用 Python tkinter 库开发的图形界面日历程序。它能够显示当前月份的日历,并允许用户通过按钮切换查看不同的月份。

2. 主要组件说明

Calendar 类

这是程序的主类,继承自 tkinter.Tk,作为整个应用的主窗口。

2.1 初始化方法 (init)
def __init__(self):
    super().__init__()
    self.title("中国日历")
    self.geometry("400x400")
  • 设置窗口标题为"中国日历"
  • 设置窗口大小为 400x400 像素
  • 初始化当前日期信息(年份和月份)
2.2 创建界面元素 (create_widgets)
def create_widgets(self):

负责创建所有界面元素,包括:

  • 顶部导航栏:包含上个月(<<)和下个月(>>)按钮
  • 年月显示标签:显示当前查看的年份和月份
  • 星期标题:显示"一"到"日"的星期标题
  • 日期网格:显示当月的所有日期
2.3 更新日历 (update_calendar)
def update_calendar(self):

这个方法负责:

  • 更新顶部的年月标题
  • 清除旧的日期按钮
  • 使用 calendar 模块获取当月日历数据
  • 创建新的日期按钮
  • 标记当前日期(用黄色背景高亮显示)
2.4 月份导航方法
def prev_month(self):    # 切换到上一个月
def next_month(self):    # 切换到下一个月

这两个方法处理月份切换:

  • prev_month:月份减1,如果是1月则年份减1并设置月份为12
  • next_month:月份加1,如果是12月则年份加1并设置月份为1

3. 程序运行流程

程序启动代码:

if __name__ == "__main__":
    app = Calendar()
    style = ttk.Style()
    style.configure('Today.TButton', background='yellow')
    app.mainloop()
  • 创建日历应用实例
  • 设置当天日期的按钮样式(黄色背景)
  • 启动主循环

4. 特色功能

  1. 直观的界面布局

    • 清晰的月份导航按钮
    • 网格化的日期显示
    • 中文星期标题
  2. 当前日期高亮

    • 自动识别并高亮显示当天日期
    • 使用黄色背景突出显示
  3. 月份导航

    • 可以无限制地向前或向后浏览月份
    • 自动处理年份的变化
  4. 自适应布局

    • 日期按钮会自动调整大小以适应窗口

5. 使用的主要模块

  • tkinter:Python 标准 GUI 库
  • ttk:提供主题化的 tkinter 部件
  • calendar:处理日历数据
  • datetime:处理日期和时间

6. 如何使用

  1. 运行程序后,会显示当前月份的日历
  2. 点击 “<<” 按钮查看上一个月
  3. 点击 “>>” 按钮查看下一个月
  4. 当天的日期会以黄色背景高亮显示
  5. 窗口可以自由调整大小,日历布局会自动适应

7. 运行要求

依赖项

  • Python 3.x
  • tkinter (通常随Python一起安装)

运行方法

在命令行中执行:

python main.py

8. 代码

import tkinter as tk
from tkinter import ttk
import calendar
from datetime import datetime

class Calendar(tk.Tk):
    def __init__(self):
        super().__init__()
        
        self.title("中国日历")
        self.geometry("400x400")
        
        self.current_date = datetime.now()
        self.current_year = self.current_date.year
        self.current_month = self.current_date.month
        
        self.create_widgets()
        
    def create_widgets(self):
        # 创建顶部导航栏
        nav_frame = ttk.Frame(self)
        nav_frame.pack(pady=10)
        
        ttk.Button(nav_frame, text="<<", command=self.prev_month).pack(side=tk.LEFT, padx=5)
        self.header_label = ttk.Label(nav_frame, text="", font=('Arial', 12, 'bold'))
        self.header_label.pack(side=tk.LEFT, padx=20)
        ttk.Button(nav_frame, text=">>", command=self.next_month).pack(side=tk.LEFT, padx=5)
        
        # 创建日历主体
        self.cal_frame = ttk.Frame(self)
        self.cal_frame.pack(expand=True, fill='both', padx=10, pady=10)
        
        # 显示星期标题
        weekdays = ["一", "二", "三", "四", "五", "六", "日"]
        for i, day in enumerate(weekdays):
            ttk.Label(self.cal_frame, text=day, font=('Arial', 10, 'bold')).grid(row=0, column=i, padx=5, pady=5)
            
        self.update_calendar()
        
    def update_calendar(self):
        # 更新标题
        self.header_label.config(text=f"{self.current_year}{self.current_month}月")
        
        # 清除旧的日期按钮
        for widget in self.cal_frame.grid_slaves():
            if int(widget.grid_info()["row"]) > 0:
                widget.destroy()
                
        # 获取当月日历
        cal = calendar.monthcalendar(self.current_year, self.current_month)
        
        # 显示日期
        for i, week in enumerate(cal):
            for j, day in enumerate(week):
                if day != 0:
                    btn = ttk.Button(self.cal_frame, text=str(day))
                    btn.grid(row=i+1, column=j, padx=2, pady=2, sticky='nsew')
                    
                    # 标记今天的日期
                    if (self.current_year == datetime.now().year and 
                        self.current_month == datetime.now().month and 
                        day == datetime.now().day):
                        btn.config(style='Today.TButton')
                        
        # 配置网格权重
        for i in range(7):
            self.cal_frame.grid_columnconfigure(i, weight=1)
            
    def prev_month(self):
        self.current_month -= 1
        if self.current_month < 1:
            self.current_month = 12
            self.current_year -= 1
        self.update_calendar()
        
    def next_month(self):
        self.current_month += 1
        if self.current_month > 12:
            self.current_month = 1
            self.current_year += 1
        self.update_calendar()

if __name__ == "__main__":
    app = Calendar()
    
    # 创建自定义样式
    style = ttk.Style()
    style.configure('Today.TButton', background='yellow')
    
    app.mainloop()

网站公告

今日签到

点亮在社区的每一天
去签到