2024年最全python学生成绩管理系统【完整版】_学生成绩管理系统python(1)

该文章描述了一个使用Python和Tkinter实现的学生数据管理系统,包括数据的录入、查询、删除和修改功能,以及通过JSON文件进行数据持久化。展示了如何使用类结构管理学生信息并提供用户界面操作。
摘要由CSDN通过智能技术生成
    self.students = []
    self._load_students_data()

def insert(self, student):
    self.students.append(student)
    print(self.students)

def all(self):
    return self.students

def delete\_by\_name(self, name):  # 删除数据
    for student in self.students:
        if name == student["name"]:
            self.students.remove(student)
            break
    else:
        return False
    return True

# 查询
def search\_by\_name(self, name):
    for student in self.students:
        if name == student["name"]:
            return student  # 姓名+成绩
    else:
        return False

# 修改
def update(self, stu):  # 修改数据
    name = stu["name"]
    for student in self.students:
        if name == student["name"]:
            student.update(stu)
            return True
    else:
        return False

# 加载文件
def \_load\_students\_data(self):
    with open("students.txt", "r", encoding="utf-8") as f:
        text = f.read()
    if text:
        self.students = json.loads(text)

# 保存数据
def save\_data(self):
    with open("students.txt", 'w', encoding="utf-8") as f:
        text = json.dumps(self.students, ensure_ascii=False)
        f.write(text)

db = StudentDB()


#### MenuPage.py



import tkinter as tk
from view import *

class MenuPage(object):
def __init__(self, master=None):
self.root = master
self.root.geometry(‘%dx%d’ % (600, 400))
self.create_page()
self.input_page = InputFrame(self.root)
self.query_page = QuerryFrame(self.root)
self.delete_page = DeleteFrame(self.root)
self.update_page = UpdateFrame(self.root)
self.about_page = AboutFrame(self.root)
self.input_page.pack()

def create\_page(self):
    # 创建菜单对象
    menubar = tk.Menu(self.root)
    # add\_command 添加
    menubar.add_command(label="录入", command=self.input_data)  # label
    menubar.add_command(label="查询", command=self.query_data)  # label
    menubar.add_command(label="删除", command=self.delete_data)  # label
    menubar.add_command(label="修改", command=self.update_data)  # label
    menubar.add_command(label="关于", command=self.about_data)  # label
    # 设置菜单栏
    self.root.config(menu=menubar)

# 切换界面
def input\_data(self):
    self.input_page.pack()
    self.update_page.pack_forget()
    self.delete_page.pack_forget()
    self.about_page.pack_forget()
    self.query_page.pack_forget()

def query\_data(self):
    self.input_page.pack_forget()
    self.query_page.pack()
    self.update_page.pack_forget()
    self.delete_page.pack_forget()
    self.about_page.pack_forget()

def update\_data(self):
    self.input_page.pack_forget()
    self.update_page.pack()
    self.delete_page.pack_forget()
    self.about_page.pack_forget()
    self.query_page.pack_forget()

def delete\_data(self):
    self.input_page.pack_forget()
    self.update_page.pack_forget()
    self.delete_page.pack()
    self.about_page.pack_forget()
    self.query_page.pack_forget()

def about\_data(self):
    self.input_page.pack_forget()
    self.update_page.pack_forget()
    self.delete_page.pack_forget()
    self.about_page.pack()
    self.query_page.pack_forget()

#### view.py



import tkinter as tk
from db import db
from tkinter import ttk

录入类

class InputFrame(tk.Frame):
def __init__(self, master=None):
super().init(master)
self.root = master
self.name = tk.StringVar()
self.math = tk.StringVar()
self.chinese = tk.StringVar()
self.english = tk.StringVar()
self.status = tk.StringVar()
self.create_page()

def create\_page(self):
    tk.Label(self).grid(row=0, stick=tk.W, pady=10)
    tk.Label(self, text="姓名:").grid(row=1, stick=tk.W, pady=10)
    # 单行文本框 entry,textvariable绑定变量
    tk.Entry(self, textvariable=self.name).grid(row=1, column=1, stick=tk.E)

    tk.Label(self, text="数学:").grid(row=2, stick=tk.W, pady=10)
    # 单行文本框 entry,textvariable绑定变量
    tk.Entry(self, textvariable=self.math).grid(row=2, column=1, stick=tk.E)

    tk.Label(self, text="语文:").grid(row=3, stick=tk.W, pady=10)
    # 单行文本框 entry,textvariable绑定变量
    tk.Entry(self, textvariable=self.chinese).grid(row=3, column=1, stick=tk.E)

    tk.Label(self, text="英语:").grid(row=4, stick=tk.W, pady=10)
    # 单行文本框 entry,textvariable绑定变量
    tk.Entry(self, textvariable=self.english).grid(row=4, column=1, stick=tk.E)

    tk.Button(self, text="录入", command=self.recode_student).grid(row=5, column=1, stick=tk.E, pady=10)
    tk.Label(self, textvariable=self.status).grid(row=6, column=1, stick=tk.E, pady=10)

# 录入成绩
def recode\_student(self):
    student = {
        "name": self.name.get(),
        "math": self.math.get(),
        "chinese": self.chinese.get(),
        "english": self.english.get(),
    }  # 一个学生的成绩
    db.insert(student)
    # get()得到值
    # set()设置值
    self.status.set("插入数据成功!")
    self._clear_data()
    db.save_data()

# 清空文本数据
def \_clear\_data(self):
    self.name.set("")
    self.math.set("")
    self.chinese.set("")
    self.english.set("")

查询类

class QuerryFrame(tk.Frame):
def __init__(self, master=None):
super().init(master)
self.root = master
self.create_page()

# 创建查询界面
def create\_page(self):
    self.create_tree_view()
    self.show_data_frame()
    # grid()
    tk.Button(self, text="刷新数据", command=self.show_data_frame).pack(anchor=tk.E, pady=5)

# Treeview
def create\_tree\_view(self):
    # 表头
    columns = ("name", "chinese", "math", "english")
    self.tree_view = ttk.Treeview(self, show='headings', columns=columns)
    self.tree_view.column("name", width=80, anchor='center')
    self.tree_view.column("chinese", width=80, anchor='center')
    self.tree_view.column("math", width=80, anchor='center')
    self.tree_view.column("english", width=80, anchor='center')
    self.tree_view.heading("name", text='姓名')
    self.tree_view.heading("chinese", text='语文')
    self.tree_view.heading("math", text='数学')
    self.tree_view.heading("english", text='英语')
    self.tree_view.pack()

# 显示数据
def show\_data\_frame(self):
    # 删除原节点 map(int,值)
    for i in map(self.tree_view.delete, self.tree_view.get_children("")):
        pass
    # 拿到列表里面所有值、students[]
    students = db.all()
    # 同时拿到索引跟value值
    for index, stu in enumerate(students):
        self.tree_view.insert('', index, values=(stu["name"], stu["chinese"], stu
        ["math"], stu["english"]))

class DeleteFrame(tk.Frame):
def __init__(self, master=None):
super().init(master)
tk.Label(self, text=‘删除数据’).pack()
self.status = tk.StringVar()
self.de_name = tk.StringVar() # 获取删除学生的姓名
self.create_page()

# 创建界面
def create\_page(self):
    tk.Label(self, text="根据姓名删除信息").pack(anchor=tk.W, padx=20)
    e1 = tk.Entry(self, textvariable=self.de_name)
    e1.pack(side=tk.LEFT, padx=20, pady=5)

    tk.Button(self, text='删除', command=self._delete).pack(side=tk.RIGHT)
    tk.Label(self, textvariable=self.status).pack()

# 删除
def \_delete(self):
    name = self.de_name.get()
    print(name)
    result = db.delete_by_name(name)
    if result:
        self.status.set(f'{name}已经被删')
        self.de_name.set("")
    else:
        self.status.set(f'{name}不存在')

class UpdateFrame(tk.Frame):
def __init__(self, master=None):
super().init(master)
self.root = master
tk.Label(self, text=‘修改界面’).pack()
self.change_frame = tk.Frame(self)
self.change_frame.pack()
self.name = tk.StringVar()
self.math = tk.StringVar()
self.chinese = tk.StringVar()
self.english = tk.StringVar()
self.status = tk.StringVar()
self.create_page()

def create\_page(self):
    tk.Label(self.change_frame).grid(row=0, stick=tk.W, pady=10)
    tk.Label(self.change_frame, text="姓名:").grid(row=1, stick=tk.W, pady=10)
    # 单行文本框 entry,textvariable绑定变量
    tk.Entry(self.change_frame, textvariable=self.name).grid(row=1, column=1, stick=tk.E)

    tk.Label(self.change_frame, text="数学:").grid(row=2, stick=tk.W, pady=10)
    # 单行文本框 entry,textvariable绑定变量
    tk.Entry(self.change_frame, textvariable=self.math).grid(row=2, column=1, stick=tk.E)

    tk.Label(self.change_frame, text="语文:").grid(row=3, stick=tk.W, pady=10)
    # 单行文本框 entry,textvariable绑定变量
    tk.Entry(self.change_frame, textvariable=self.chinese).grid(row=3, column=1, stick=tk.E)

    tk.Label(self.change_frame, text="英语:").grid(row=4, stick=tk.W, pady=10)
    # 单行文本框 entry,textvariable绑定变量
    tk.Entry(self.change_frame, textvariable=self.english).grid(row=4, column=1, stick=tk.E)

    # 按钮
    tk.Button(self.change_frame, text='查询', command=self._search).grid(row=6, column=0, stick=tk.W, pady=10)
    tk.Button(self.change_frame, text='修改', command=self._change).grid(row=6, column=1, stick=tk.E, pady=10)

    tk.Label(self.change_frame, textvariable=self.status).grid(row=7, column=1, stick=tk.E, pady=10)

# 查询

做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。

别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。

我先来介绍一下这些东西怎么用,文末抱走。


(1)Python所有方向的学习路线(新版)

这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

最近我才对这些路线做了一下新的更新,知识体系更全面了。

在这里插入图片描述

(2)Python学习视频

包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。

在这里插入图片描述

(3)100多个练手项目

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。

在这里插入图片描述

(4)200多本电子书

这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。

基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。

(5)Python知识点汇总

知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。

在这里插入图片描述

(6)其他资料

还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。

在这里插入图片描述

这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里无偿获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 20
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值