这将使你见过最全面的Python制作GUI学生管理系统教程

打印 上一主题 下一主题

主题 847|帖子 847|积分 2541

表弟大学快毕业了,学了一个学期Python居然还不会写学生管理系统,真的给我丢脸啊,教他又不肯学,还让我直接给他写,我真想两巴掌上去,最终还是写了给他,谁让他是我表弟呢,关键时候还是得帮他一把!

 
 
 

写完了放在那也是放着,所以今天分享给大家吧!
话不多说,咱们直接开始吧!

 
 
代码解析

一、登录页面

1、定义登录类及初始化对象

首先导入咱们需要用到的模块
  1. from main import MainPage
  2. # 文章看不懂,我专门录了对应的视频讲解,完整代码和视频教程加群获取。
  3. # Python学习交流1裙:815624229  一群已满加2群 ###
  4. # Python学习交流2裙:279199867 ###
复制代码
 
登录页面
将画板绑定到实例对象
  1. self.root = master
复制代码
 
self.page 画纸 在屏幕上显示一个矩形区域,多用来作为容器。
  1. self.page = tk.Frame(self.root)
  2. self.page.pack()
  3. self.root.geometry("300x180")
复制代码
 
tkinter 提供的可变变量,定义用户名和密码.
  1. self.username = tk.StringVar()
  2. self.password = tk.StringVar()
复制代码
 
创建一个label
网格布局
  1. tk.Label(self.page).grid(row=0, column=0)
  2. # textvariable 这个参数是把 tkinter 里面的字符串变量与 空间绑定起来
  3. tk.Label(self.page, text="账户").grid(row=1, column=0, stick=tk.E, pady=10)
  4. tk.Entry(self.page, textvariable=self.username).grid(row=1, column=1, stick=tk.W, pady=10)
  5. tk.Label(self.page, text="密码").grid(row=2, column=0, stick=tk.E, pady=10)
  6. tk.Entry(self.page, textvariable=self.password).grid(row=2, column=1, stick=tk.W, pady=10)
复制代码
 
command 接受一个函数 执行登录的逻辑
  1. tk.Button(self.page, text="登录", command=self.login_check).grid(row=3, column=0, stick=tk.W, pady=10)
  2. tk.Button(self.page, text="退出", command=root.quit).grid(row=3, column=1, stick=tk.E, pady=10)
复制代码
 
2、登录函数

检验登录
拿到账号密码
  1. name = self.username.get()
  2. pwd = self.password.get()
复制代码
 
不去查询数据库
  1. print(name, pwd)
  2. if name == 'admin' and pwd == '123456':
  3.     tkinter.messagebox.showinfo(title='恭喜',
  4.                                 message='登录成功!')
复制代码
 
摧毁当前页面绘制的内容
  1. self.page.destroy()
复制代码
 
摧毁整个页面绘制的内容
  1. self.root.destroy()
复制代码
 
页面的切换
  1.     MainPage(self.root)
  2. else:
  3.     tkinter.messagebox.showinfo(title='错误', message='账户或者密码错误')
复制代码
 
3、窗口调用

调用本文件方法,在本文件运行两个输入,在外面调用执行这个方法前面的数据。
创建一个对象,窗口对象,显示界面.
  1. if __name__ == '__main__':
  2.     root = tk.Tk()
  3.     LoginPage(root)
  4.     root.mainloop()
复制代码
 
二、主页面显示

1、定义页面类,方便调用.

登录界面
  1. def __init__(self, master):
  2.     self.root = master
  3.    
  4.     self.page = tk.Frame(self.root)
  5.     self.page.pack()
  6.     self.root.geometry("%dx%d" % (600, 400))
  7.     self.create_page()
复制代码
 
创建一个顶级菜单,显示菜单.
  1. def create_page(self):
  2.     menubar = tk.Menu(self.root)
  3.     menubar.add_command(label="录入")
  4.     menubar.add_command(label="查询")
  5.     menubar.add_command(label="删除")
  6.     menubar.add_command(label="修改")
  7.     menubar.add_command(label="关于")
复制代码
 
三 、页面显示

1、绑定各个页面

写在一起代码太多,数据多,容易写错,混乱,可以写一个文件专门来装数据view.py
在view.py文件定义各个模块的类
录入
  1. class InputFrame(tk.Frame):  # 继承Frame类
  2.     def __init__(self, master):
  3.         # 重新父类
  4.         super().__init__(master)
  5.         pass
复制代码
 
查询
  1. class QueryFrame(tk.Frame):  # 继承Frame类
  2.     def __init__(self, master=None):
  3.         super().__init__(master)
  4.         pass
复制代码
 
删除
  1. class DeleteFrame(tk.Frame):  # 继承Frame类
  2.     def __init__(self, master=None):
  3.         super().__init__(master)
复制代码
 
修改
  1. class ChangeFrame(tk.Frame):  # 继承Frame类
  2.     def __init__(self, master=None):
  3.         super().__init__(master)
复制代码
 
关于
  1. class AboutFrame(tk.Frame):  # 继承Frame类
  2.     def __init__(self, master=None):
  3.         tk.Frame.__init__(self, master)
  4.         self.root = master
复制代码
 
然后在main.py文件中绑定这些数据
  1. self.input_page = InputFrame(self.root)
  2. self.change_page = ChangeFrame(self.root)
  3. self.query_page = QueryFrame(self.root)
  4. self.delete_page = DeleteFrame(self.root)
  5. self.about_page = AboutFrame(self.root)
复制代码
 
2、录入

在view.py文件中InputFrame类中添加相关内容,名字以及成绩。

  • x = IntVar():整型变量,默认是0
  • x = DoubleVar():浮点型变量,默认是0.0
  • x = StringVar():字符串变量,默认是""
  • x = BooleanVar():布尔型变量,True是1,False是0
  1. self.root = master  # 定义内部变量root
  2. self.name = tk.StringVar()
  3. self.math = tk.StringVar()
  4. self.chinese = tk.StringVar()
  5. self.english = tk.StringVar()
  6. # 录入
  7. self.status = tk.StringVar()
  8. # 调用create_page()函数
  9. self.create_page()
复制代码
 
编写create_page()函数
  1. def create_page(self):
  2.     # pass
  3.     # stick 控件对象方向 tk.W 西方位
  4.     # pady padding y 上下的宽度
  5.     # row 行 表格布局
  6.     tk.Label(self).grid(row=0, stick=tk.W, pady=10)
  7.     tk.Label(self, text='姓 名: ').grid(row=1, stick=tk.W, pady=10)
  8.     # text variable 绑定控件里面的数据内容
  9.     tk.Entry(self, textvariable=self.name).grid(row=1, column=1, stick=tk.E)
  10.     tk.Label(self, text='数 学: ').grid(row=2, stick=tk.W, pady=10)
  11.     tk.Entry(self, textvariable=self.math).grid(row=2, column=1, stick=tk.E)
  12.     tk.Label(self, text='语 文: ').grid(row=3, stick=tk.W, pady=10)
  13.     tk.Entry(self, textvariable=self.chinese).grid(row=3, column=1, stick=tk.E)
  14.     tk.Label(self, text='英 语: ').grid(row=4, stick=tk.W, pady=10)
  15.     tk.Entry(self, textvariable=self.english).grid(row=4, column=1, stick=tk.E)
  16.     tk.Button(self, text='录入', command=self.recode_student).grid(row=5, column=1, stick=tk.E, pady=10)
  17.     tk.Label(self, textvariable=self.status).grid(row=6, column=1, stick=tk.E, pady=10)
复制代码
 
在main.py中绑定这些数据
  1. menubar.add_command(label="录入", command=self.show_input)
  2. def show_input(self):
  3.     self.input_page.pack()
  4.     # pack_forget()隐藏布局
  5.     # self.change_page.pack_forget()
  6.     # self.query_page.pack_forget()
  7.     # self.delete_page.pack_forget()
  8.     # self.about_page.pack_forget()
复制代码
 
在view.py文件中数据录入
  1. def recode_student(self):
  2.     stu = {'name': self.name.get(), 'chinese': self.chinese.get(),
  3.              'math': self.math.get(), 'english': self.english.get()}
  4.     # 点击录入之后需要刷新页面
  5.     self.name.set('')
  6.     self.chinese.set('')
  7.     self.math.set('')
  8.     self.english.set('')
  9.     db.insert(stu)
  10.     self.status.set('提交数据成功')
  11.     print(stu)
复制代码
 
插入数据及保存数据,可以写一个文件保存,写在一起代码量太大,出现错误机率也大写一个db.py文件.
  1. class StudentsDB:
  2.     def __init__(self):
  3.         self.students = []
  4.     def insert(self, student):
  5.         self.students.append(student)
  6. db = StudentsDB()
  7. if __name__ == '__main__':
  8.     print(db.students)
复制代码
 
四、查询数据

在QueryFrame()类添加数据

  • ttk.Treeview 树视图,百度一下
  • shows:
    headings
    tree
    data_list
  • columns
    值是一个列表。列表里每个元素代表一个列标识符的名称。列表的长度为列的长度。
继承Frame类
  1. class QueryFrame(tk.Frame):  
  2.     def __init__(self, master=None):
  3.         super().__init__(master)
复制代码
 
定义内部变量root
  1. self.root = master  #
  2. columns = ('name', 'chinese', 'math', 'english')
  3. self.tree_view = ttk.Treeview(self, show='headings', columns=columns)
复制代码
 
每个数据大小每一格
  1. self.tree_view.column('name', width=80, anchor='center')
  2. self.tree_view.column('chinese', width=80, anchor='center')
  3. self.tree_view.column('math', width=80, anchor='center')
  4. self.tree_view.column('english', width=80, anchor='center')
复制代码
 
上面的标签及headings
  1. self.tree_view.heading('name', text='姓名')
  2. self.tree_view.heading('chinese', text='语文')
  3. self.tree_view.heading('math', text='数学')
  4. self.tree_view.heading('english', text='英语')
  5. self.tree_view.pack(fill=tk.BOTH, expand=True)
  6. tk.Button(self, text='刷新数据', command=self.show_data_frame).pack(anchor=tk.E, pady=5)
  7. self.show_data_frame()
复制代码
 
刷新数据,显示数据.
  1. def show_data_frame(self):
  2.     # 删除旧的阶段
  3.     for _ in map(self.tree_view.delete, self.tree_view.get_children('')):
  4.         pass
  5.     # 先要显示所有数据 在db文件加入显示数据代码
  6.     students = db.all()
  7.     index = 0
  8.     for stu in students:
  9.         # print(stu)
  10.         self.tree_view.insert('', index + 1, values=(
  11.             stu['name'], stu['chinese'], stu['math'], stu['english'],
  12.         ))
复制代码
 
显示数据
在db.py中加
  1. def all(self):
  2.     return self.students
复制代码
 
view.py
刷新插入数据

  • 第一个参数:parent : 对于有树栏的Treeview,parent是父节点,对于只是列表栏的Treeview,parent一般为空。
  • 第二个参数:index :插入位置。可以是END或’end’ ,也可以是数字的,如果你想新插入的item(记录)成为第某节点的第一个,index就设为0,以此类推。
  • values:显示的值及插入的数据,这一列数据。
  1. self.tree_view.insert('', index + 1, values=(
  2.                 stu['name'], stu['chinese'], stu['math'],                                 stu['english'],
  3.             ))
复制代码
 
插入数据刷新后更新页面

  • map(func, lst),将传入的函数变量func作用到lst变量的每个元素中,并将结果组成新的列表(Python2)/迭代器(Python3)返回。
  • get_children(item=None)
返回一个item的所有子item,这个子item是一个列表形式,如果item没指定,则返回根目录的item
  1. for _ in map(self.tree_view.delete, self.tree_view.get_children('')):
  2.             pass
复制代码
 
在main.py文件绑定数据
  1.     menubar.add_command(label="查询", command=self.show_all)
  2. def show_all(self):
  3.     # 隐藏布局
  4.     self.input_page.pack_forget()
  5.     # self.change_page.pack_forget()
  6.     self.query_page.pack()
  7.     # self.delete_page.pack_forget()
  8.     # self.about_page.pack_forget()
复制代码
 
五、删除数据

在DeleteFrame()类添加数据
  1. class DeleteFrame(tk.Frame):  # 继承Frame类
  2.     def __init__(self, master=None):
  3.         super().__init__(master)        self.root = master  # 定义内部变量root        tk.Label(self, text='删除数据').pack()        self.delete_frame = tk.Frame(self)        self.delete_frame.pack()        self.status = tk.StringVar()        self.username = tk.StringVar()        tk.Label(self.delete_frame, text='根据名字删除信息').pack(anchor=tk.W, padx=20)        tk.Entry(self.delete_frame, textvariable=self.username).pack(side=tk.LEFT, padx=20, pady=5)        tk.Button(self.delete_frame, text='删除', command=self._delete).pack()        tk.Label(self, textvariable=self.status).pack()
复制代码
 
1、点击删除,删除数据
  1. def _delete(self):
  2.     username = self.username.get()
  3.     flag, message = db.delete_by_name(username)
  4.     self.status.set(message)
复制代码
 
在db.py文件中添加删除逻辑
  1. def delete_by_name(self, name):
  2.     for student in self.students:
  3.         if name == student['name']:
  4.             self.students.remove(student)
  5.             return True, f'{name} 删除成功'
  6.     return False, f'{name} 不存在'
复制代码
 
在main.py中绑定数据
  1.     menubar.add_command(label="删除", command=self.show_delete)
  2. def show_delete(self):
  3.     self.input_page.pack_forget()
  4.     self.query_page.pack_forget()
  5.     self.delete_page.pack()
复制代码
 
六、修改数据

在ChangeFrame()类添加数据
  1. self.root = master  # 定义内部变量root
  2.         tk.Label(self, text='修改界面').pack()
  3.         self.change_frame = tk.Frame(self)
  4.         self.change_frame.pack()
  5.         self.status = tk.StringVar()
  6.         self.name = tk.StringVar()
  7.         self.math = tk.StringVar()
  8.         self.chinese = tk.StringVar()
  9.         self.english = tk.StringVar()
  10.         tk.Label(self.change_frame).grid(row=0, stick=tk.W, pady=1)
  11.         tk.Label(self.change_frame, text='姓 名: ').grid(row=1, stick=tk.W, pady=10)
  12.         tk.Entry(self.change_frame, textvariable=self.name).grid(row=1, column=1, stick=tk.E)
  13.         tk.Label(self.change_frame, text='数 学: ').grid(row=2, stick=tk.W, pady=10)
  14.         tk.Entry(self.change_frame, textvariable=self.math).grid(row=2, column=1, stick=tk.E)
  15.         tk.Label(self.change_frame, text='语 文: ').grid(row=3, stick=tk.W, pady=10)
  16.         tk.Entry(self.change_frame, textvariable=self.chinese).grid(row=3, column=1, stick=tk.E)
  17.         tk.Label(self.change_frame, text='英 语: ').grid(row=4, stick=tk.W, pady=10)
  18.         tk.Entry(self.change_frame, textvariable=self.english).grid(row=4, column=1, stick=tk.E)
  19.         tk.Button(self.change_frame, text='查询', command=self._search).grid(row=6, column=0, stick=tk.W, pady=10)
  20.         tk.Button(self.change_frame, text='修改', command=self._change).grid(row=6, column=1, stick=tk.E, pady=10)
  21.         tk.Label(self.change_frame, textvariable=self.status).grid(row=7, column=1, stick=tk.E, pady=10)
复制代码
 
1、查询数据

db.py文件中查询数据逻辑
  1. def search_by_name(self, name):
  2.     for student in self.students:
  3.         if name == student['name']:
  4.             return True, student
  5.     return False, f'{name} 不存在'
复制代码
 
view.py文件点击查询,显示数据
  1. def _search(self):
  2.     flag, info = db.search_by_name(self.name.get())
  3.     if flag:
  4.         self.name.set(info['name'])
  5.         self.chinese.set(info['chinese'])
  6.         self.math.set(info['math'])
  7.         self.english.set(info['english'])
  8.         self.status.set('数据查询成功')
  9.     else:
  10.         # 直接返回错误的信息
  11.         self.status.set(info)
复制代码
 
2、修改数据及更新

db.py文件更新数据逻辑
  1. def update(self, stu):
  2.     name = stu['name']
  3.     for student in self.students:
  4.         if name == student['name']:
  5.             student.update(stu)
  6.             return True, f'{stu["name"]} 用户数据修改成功'
  7.     else:
  8.         return False, f'{name} 不存在'
复制代码
 
view.py文件修改数据
  1. def _change(self):
  2.     stu = {'name': self.name.get(), 'chinese': self.chinese.get(),
  3.            'math': self.math.get(), 'english': self.english.get(), }
  4.     self.name.set('')
  5.     self.chinese.set('')
  6.     self.math.set('')
  7.     self.english.set('')
  8.     db.update(stu)
  9.     self.status.set('修改数据成功')
复制代码
 
main.py文件进行绑定
  1.     menubar.add_command(label="修改", command=self.show_change)
  2. def show_change(self):
  3.     self.input_page.pack_forget()
  4.     self.query_page.pack_forget()
  5.     self.delete_page.pack_forget()
  6.     self.change_page.pack()
复制代码
 
七、关于部分

view.py中在AboutFrame()添加数据
  1. class AboutFrame(tk.Frame):  # 继承Frame类
  2.     def __init__(self, master=None):
  3.         tk.Frame.__init__(self, master)
  4.         self.root = master  # 定义内部变量root        tk.Label(self, text='关于作品:本作品由 嗨学编程 制作').pack(anchor=tk.W)        tk.Label(self, text='关于作者:嗨学编程').pack(anchor=tk.W)        tk.Label(self, text='版权所有:嗨学编程').pack(anchor=tk.W)
复制代码
 
main.py绑定数据
  1.     menubar.add_command(label="关于", command=self.show_about)
  2. def show_about(self):
  3.     self.input_page.pack_forget()
  4.     self.query_page.pack_forget()
  5.     self.delete_page.pack_forget()
  6.     self.change_page.pack_forget()
  7.     self.about_page.pack()
复制代码
 
八、数据保存,保存信息

db.py对数据保存
创建空json文件
  1. import os
  2. file = "students.json"
  3. # 判断文件是否存在,不存在则创建
  4. if not os.path.exists(file):
  5.     open(file, 'w')
  6.     # 报错
  7.     # os.mknod(file)
复制代码
 

  • Windows上的Python不支持mknod函数,因为在Windows上没有node这个概念。
1、保存数据
  1. def save_data(self):
  2.     with open('students.json', mode='w', encoding='utf-8') as f:
  3.         text = json.dumps(self.students, indent=2, ensure_ascii=False)
  4.         f.write(text)
复制代码
 
2 、读取数据
  1. def _load_students_data(self):
  2.     with open('students.json', mode='r', encoding='utf-8') as f:
  3.         text = f.read()
  4.     if text:
  5.         self.students = json.loads(text)
复制代码
 
在view.py文件中调用保存函数,对完成后的数据进行保存。
录入
  1. def recode_student(self):
  2.     db.save_data()
复制代码
 
删除
  1. def _delete(self):
  2.     db.save_data()
复制代码
 
修改
  1. def _change(self):
  2.     db.save_data()
复制代码
 
好了今天的分享就到这里,兄弟们下次见!
大家觉得有帮助的话,顺手点个关注+赞+收藏吧,爱你们!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

悠扬随风

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表