python项目练习——14.学生管理系统

这个项目可以让用户管理学生的信息,包括学生的姓名、年龄、成绩等,并提供添加、编辑、删除、查询等功能。这个项目涉及到数据库操作、用户界面设计、数据验证等方面的技术。

代码示例:

import tkinter as tk # 导入 Tkinter 库

import sqlite3 # 导入 sqlite3 库

class StudentManagementApp:

def init(self, master):

self.master = master

self.master.title('学生管理系统')

连接到数据库

self.conn = sqlite3.connect('students.db')

self.cursor = self.conn.cursor()

self.create_table()

创建界面组件

self.label_name = tk.Label(master, text='姓名:')

self.label_name.grid(row=0, column=0)

self.entry_name = tk.Entry(master)

self.entry_name.grid(row=0, column=1)

self.label_age = tk.Label(master, text='年龄:')

self.label_age.grid(row=1, column=0)

self.entry_age = tk.Entry(master)

self.entry_age.grid(row=1, column=1)

self.label_score = tk.Label(master, text='成绩:')

self.label_score.grid(row=2, column=0)

self.entry_score = tk.Entry(master)

self.entry_score.grid(row=2, column=1)

self.btn_add = tk.Button(master, text='添加', command=self.add_student)

self.btn_add.grid(row=3, column=0, columnspan=2)

self.btn_display = tk.Button(master, text='显示全部', command=self.display_students)

self.btn_display.grid(row=4, column=0, columnspan=2)

self.textbox = tk.Text(master)

self.textbox.grid(row=5, column=0, columnspan=2)

def create_table(self):

创建学生表

self.cursor.execute('''CREATE TABLE IF NOT EXISTS students (

id INTEGER PRIMARY KEY AUTOINCREMENT,

name TEXT NOT NULL,

age INTEGER,

score REAL

)''')

self.conn.commit()

def add_student(self):

name = self.entry_name.get()

age = self.entry_age.get()

score = self.entry_score.get()

if name and age and score:

插入学生数据到数据库

self.cursor.execute('INSERT INTO students (name, age, score) VALUES (?, ?, ?)', (name, age, score))

self.conn.commit()

def display_students(self):

查询所有学生数据并显示在文本框中

self.textbox.delete('1.0', tk.END)

self.cursor.execute('SELECT * FROM students')

students = self.cursor.fetchall()

for student in students:

self.textbox.insert(tk.END, f'ID: {student[0]}, 姓名: {student[1]}, 年龄: {student[2]}, 成绩: {student[3]}\n')

if name == 'main':

root = tk.Tk() # 创建主窗口

app = StudentManagementApp(root) # 创建学生管理系统应用程序实例

root.mainloop() # 运行主事件循环

代码逻辑分析:

使用 Tkinter 库创建了一个简单的图形界面学生管理系统应用程序。用户可以在输入框中输入学生的姓名、年龄、成绩,点击添加按钮将学生信息添加到数据库中,并点击显示全部按钮可以查看所有学生的信息。学生信息存储在 SQLite 数据库中,通过 sqlite3 模块进行数据库操作。

相关推荐
Max_uuc8 分钟前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++
简佐义的博客8 分钟前
生信入门进阶指南:学习顶级实验室多组学整合方案,构建肾脏细胞空间分子图谱
人工智能·学习
白日做梦Q8 分钟前
Anchor-free检测器全解析:CenterNet vs FCOS
python·深度学习·神经网络·目标检测·机器学习
故事不长丨9 分钟前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
近津薪荼10 分钟前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
牵牛老人12 分钟前
【Qt 开发后台服务避坑指南:从库存管理系统开发出现的问题来看后台开发常见问题与解决方案】
开发语言·qt·系统架构
小Tomkk15 分钟前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
froginwe1120 分钟前
Python3与MySQL的连接:使用mysql-connector
开发语言
喵手23 分钟前
Python爬虫实战:公共自行车站点智能采集系统 - 从零构建生产级爬虫的完整实战(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集公共自行车站点·公共自行车站点智能采集系统·采集公共自行车站点导出csv
喵手30 分钟前
Python爬虫实战:地图 POI + 行政区反查实战 - 商圈热力数据准备完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·地区poi·行政区反查·商圈热力数据采集