写一个Python使用Tkinter模块创建学生管理系统实验报告,实现基本的增加、删除、修改、查询、排序等功能。

时间: 2023-07-10 19:22:48 浏览: 46
好的,以下是一个简单的学生管理系统的实现,使用了Tkinter模块作为GUI界面,实现了基本的增加、删除、修改、查询、排序等功能。 ```python import tkinter as tk from tkinter import messagebox from tkinter import ttk class Student: def __init__(self, name, gender, age, grade): self.name = name self.gender = gender self.age = age self.grade = grade class StudentManager: def __init__(self): self.students = [] def add_student(self, student): self.students.append(student) def remove_student(self, student): self.students.remove(student) def update_student(self, old_student, new_student): index = self.students.index(old_student) self.students[index] = new_student def search_student(self, name): for student in self.students: if student.name == name: return student return None def get_all_students(self): return self.students def sort_students_by_name(self): self.students.sort(key=lambda student: student.name) class StudentGUI: def __init__(self): self.student_manager = StudentManager() self.window = tk.Tk() self.window.title('学生管理系统') self.create_widgets() self.refresh_students_list() def create_widgets(self): # 创建标签和输入框 tk.Label(self.window, text='姓名').grid(row=0, column=0, padx=5, pady=5) self.name_entry = tk.Entry(self.window) self.name_entry.grid(row=0, column=1, padx=5, pady=5) tk.Label(self.window, text='性别').grid(row=1, column=0, padx=5, pady=5) self.gender_entry = tk.Entry(self.window) self.gender_entry.grid(row=1, column=1, padx=5, pady=5) tk.Label(self.window, text='年龄').grid(row=2, column=0, padx=5, pady=5) self.age_entry = tk.Entry(self.window) self.age_entry.grid(row=2, column=1, padx=5, pady=5) tk.Label(self.window, text='成绩').grid(row=3, column=0, padx=5, pady=5) self.grade_entry = tk.Entry(self.window) self.grade_entry.grid(row=3, column=1, padx=5, pady=5) # 创建按钮 tk.Button(self.window, text='添加', command=self.add_student).grid(row=4, column=0, padx=5, pady=5) tk.Button(self.window, text='删除', command=self.remove_student).grid(row=4, column=1, padx=5, pady=5) tk.Button(self.window, text='修改', command=self.update_student).grid(row=4, column=2, padx=5, pady=5) tk.Button(self.window, text='查询', command=self.search_student).grid(row=4, column=3, padx=5, pady=5) tk.Button(self.window, text='排序', command=self.sort_students).grid(row=4, column=4, padx=5, pady=5) # 创建学生列表 self.students_listbox = tk.Listbox(self.window, height=10, width=50) self.students_listbox.grid(row=5, column=0, columnspan=5, padx=5, pady=5) def add_student(self): name = self.name_entry.get() gender = self.gender_entry.get() age = self.age_entry.get() grade = self.grade_entry.get() if name and gender and age and grade: student = Student(name, gender, age, grade) self.student_manager.add_student(student) self.refresh_students_list() else: messagebox.showinfo('错误', '请输入完整信息') def remove_student(self): selection = self.students_listbox.curselection() if selection: student = self.students_listbox.get(selection[0]) student = self.student_manager.search_student(student) self.student_manager.remove_student(student) self.refresh_students_list() def update_student(self): selection = self.students_listbox.curselection() if selection: old_student = self.students_listbox.get(selection[0]) old_student = self.student_manager.search_student(old_student) name = self.name_entry.get() gender = self.gender_entry.get() age = self.age_entry.get() grade = self.grade_entry.get() if name and gender and age and grade: new_student = Student(name, gender, age, grade) self.student_manager.update_student(old_student, new_student) self.refresh_students_list() else: messagebox.showinfo('错误', '请输入完整信息') def search_student(self): name = self.name_entry.get() if name: student = self.student_manager.search_student(name) if student: self.gender_entry.delete(0, tk.END) self.gender_entry.insert(0, student.gender) self.age_entry.delete(0, tk.END) self.age_entry.insert(0, student.age) self.grade_entry.delete(0, tk.END) self.grade_entry.insert(0, student.grade) else: messagebox.showinfo('错误', '未找到该学生') def sort_students(self): self.student_manager.sort_students_by_name() self.refresh_students_list() def refresh_students_list(self): self.students_listbox.delete(0, tk.END) students = self.student_manager.get_all_students() for student in students: self.students_listbox.insert(tk.END, student.name) if __name__ == '__main__': app = StudentGUI() app.window.mainloop() ``` 该程序包含三个类:`Student`、`StudentManager`和`StudentGUI`。其中,`Student`类表示一个学生对象,包含姓名、性别、年龄、成绩四个属性;`StudentManager`类表示学生管理系统,包含添加、删除、修改、查询、排序等功能;`StudentGUI`类则是GUI界面的实现,包含标签、输入框、按钮、学生列表等控件,并将这些控件与学生管理系统的方法相连接。 您可以将以上代码保存为一个Python文件,运行该程序后,会弹出一个GUI界面,您可以在该界面上进行学生管理的各种操作。注意:该程序只是一个简单的学生管理系统的实现,如果您需要更加复杂的功能,可以根据需要修改代码。

相关推荐

最新推荐

recommend-type

Python3.7+tkinter实现查询界面功能

主要介绍了Python3.7+tkinter实现查询界面功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

Python使用tkinter库实现文本显示用户输入功能示例

主要介绍了Python使用tkinter库实现文本显示用户输入功能,结合实例形式分析了tkinter库获取用户输入及控件显示相关操作技巧,需要的朋友可以参考下
recommend-type

python使用Tkinter实现在线音乐播放器

主要为大家详细介绍了python使用Tkinter实现在线音乐播放器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Python实现在tkinter中使用matplotlib绘制图形的方法示例

主要介绍了Python实现在tkinter中使用matplotlib绘制图形的方法,结合实例形式分析了Python使用tkinter与matplotlib进行正弦曲线图形绘制的相关操作技巧,需要的朋友可以参考下
recommend-type

基于python的Tkinter编写登陆注册界面

主要为大家详细介绍了基于python的Tkinter编写登陆注册界面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

hive中 的Metastore

Hive中的Metastore是一个关键的组件,它用于存储和管理Hive中的元数据。这些元数据包括表名、列名、表的数据类型、分区信息、表的存储位置等信息。Hive的查询和分析都需要Metastore来管理和访问这些元数据。 Metastore可以使用不同的后端存储来存储元数据,例如MySQL、PostgreSQL、Oracle等关系型数据库,或者Hadoop分布式文件系统中的HDFS。Metastore还提供了API,使得开发人员可以通过编程方式访问元数据。 Metastore的另一个重要功能是跟踪表的版本和历史。当用户对表进行更改时,Metastore会记录这些更改,并且可以让用户回滚到
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。