首先创建主窗口并设置标题和大小,然后导入tkinter、calendar和datetime模块;接着获取当前年月作为默认显示,定义函数展示日历数据,通过下拉框选择年月并点击按钮更新日历,使用Frame容器布局日期,最后初始化显示当前月日历并运行程序。

用 Python 的 tkinter 制作一个简单的日历界面并不复杂,主要借助 tkinter 创建窗口和控件,再结合 calendar 模块生成日历数据。以下是实现的基本步骤:
1. 导入所需模块
需要导入 tkinter 用于界面显示,calendar 用于获取月份的日历数据,datetime 获取当前日期。
import tkinter as tk from tkinter import ttk import calendar from datetime import datetime
2. 创建主窗口
初始化 tkinter 窗口,设置标题和基本大小。
root = tk.Tk()
root.title("简易日历")
root.geometry("400x300")
3. 获取并显示当前年月
使用 datetime 获取当前年月,作为默认显示内容。
立即学习“Python免费学习笔记(深入)”;
today = datetime.now() year = today.year month = today.month
4. 定义显示日历的函数
该函数根据指定年月生成日历,并在界面中展示。可用 Text 或 Label 配合 grid 布局显示日期。
def show_calendar(year, month):
# 清除旧内容
for widget in frame.winfo_children():
widget.destroy()
# 显示星期标题
days = ["日", "一", "二", "三", "四", "五", "六"]
for i, day in enumerate(days):
label = tk.Label(frame, text=day, font=("Arial", 10), width=4, height=2)
label.grid(row=0, column=i)
# 获取当月日历(二维列表)
cal = calendar.monthcalendar(year, month)
for r, week in enumerate(cal, start=1):
for c, day in enumerate(week):
if day == 0:
text = ""
else:
text = str(day)
label = tk.Label(frame, text=text, font=("Arial", 10), width=4, height=2,
relief="solid")
label.grid(row=r, column=c)5. 添加年月切换控件
加入下拉菜单或按钮,让用户切换年份和月份。
# 年份选择 year_var = tk.StringVar(value=year) year_combo = ttk.Combobox(root, textvariable=year_var, values=list(range(year-10, year+11)), width=6) year_combo.grid(row=0, column=0, padx=5, pady=5)月份选择
month_var = tk.StringVar(value=month) month_combo = ttk.Combobox(root, textvariable=month_var, values=list(range(1, 13)), width=4) month_combo.grid(row=0, column=1, padx=5, pady=5)
更新按钮
update_btn = tk.Button(root, text="显示", command=lambda: show_calendar(int(year_var.get()), int(month_var.get()))) update_btn.grid(row=0, column=2, padx=5, pady=5)
6. 创建日历显示区域
使用一个 Frame 作为容器,放置日历格子。
frame = tk.Frame(root) frame.grid(row=1, column=0, columnspan=3)
7. 初始化显示
启动时自动显示当前月份的日历。
show_calendar(year, month) root.mainloop()
基本上就这些。通过以上步骤,你就能得到一个可切换年月的简单日历界面。功能可以进一步扩展,比如高亮当天、点击事件等。











