python3 tkinter和pandas学生信息管理系统
文章目录
2021/05/11更新 增加跑起来程序的说明和指导
页面跳转逻辑清晰,tkinter布局合理
0. 代码
仓库:
https://github.com/randolphcyg/husky_pywork/tree/master/sims_tk
1. 部署准备
一般大家下载安装python发行版本即可,推荐至少3.6以上,会自带pip包管理工具,注意配置下pip为国内源,用pip安装以下几个库
xlrd、openpyxl、pillow、pandas;
你跑代码的IDE可以是pycharm或者vscode。如果是全局的python和包环境,直接将全局环境配置进去即可;如果是用pipenv分离的python各项目的环境,更好管理。
1.1. 演示

用python解释器跑main.py文件,出现如上有依赖没安装的情况,安装依赖接着跑一遍:

进cmd用 python main.py命令行跑也成,例子如下:

2.演示
2.1 登录
- 用户
admin - 密码
admin
可在登录代码里面自行配置

登录成功效果

用户名密码写在了临时文件中,位置:
C:\Users\randolph\AppData\Local\Temp下,此处randolph为我的用户名

2.2 新增
学科项目为浮点数存储,可以自行修改前端label显示字样满足自定义

2.3 删除

2.4 修改

2.5 报表

2.6 关于页面

2.7 用户模块
可以注销回到登录界面,或者直接退出关闭窗口

3.代码讲解
main.py作为程序的入口
LoginPage.py程序登录的实现
MainPage.py菜单跳转实现
view.py各功能页面及其数据处理功能的集成
Tools.py工具类,用来放常调用的通用工具方法
- 关于tkinter知识点
- tkinter的页面跳转逻辑、登录校验用临时文件夹、tkinter布局方式采用最优的grid方式(不建议用pack和place方式),TEST_开头的俩py文件最开始用的是place方式(最笨的方式)、颜色管理见 tkinter颜色、唯一ID是学号、各种数据的校验逻辑、pandas增删改csv文件的逻辑(尤其是删除)
字体见Python+tkinter设置Label字体、字号、样式、对齐方式、鼠标形状、响应鼠标事件
4.拓展思考
报表页面的绩点gpa的计算方式现在没有根据各科的课程学分计算,默认所有课程学分一致不是很合理。
5.其他tkinter代码片段
此片段从其他博客修改过来,找不到源博客源了,作为tkinter布局的demo

import tkinter as tk
import tkinter.font as tkFont
import tkinter.messagebox
import tkinter.ttk as ttk
class MForm(tk.Frame):
'''继承自Frame类,master 为Tk类顶级窗体(带标题栏、最大、最小、关闭按钮)'''
def __init__(self, master=None):
super().__init__(master)
self.initComponent(master)
def initMenu(self, master):
mbar = tk.Menu(master) # 定义顶级菜单实例
fmenu = tk.Menu(mbar, tearoff=False) # 在顶级菜单下创建菜单项
mbar.add_cascade(label=' 文件 ', menu=fmenu, font=('Times', 20, 'bold')) # 添加子菜单
fmenu.add_command(label="打开", command=self.menu_click_event)
fmenu.add_command(label="保存", command=self.menu_click_event)
fmenu.add_separator() # 添加分割线
fmenu.add_command(label="退出", command=master.quit())
etmenu = tk.Menu(mbar, tearoff=False)
mbar.add_cascade(label=' 编辑 ', menu=etmenu)
for each in ['复制', '剪切', '合并']:
etmenu.add_command(label=each, command=self.menu_click_event)
master.config(menu=mbar) # 将顶级菜单注册到窗体
def menu_click_event(self):
'''菜单事件'''
pass
def initPlayList(self):
'''初始化树状视图'''
self.frm_left.rowconfigure(0, weight=1) # 左侧Frame帧行列权重配置以便子元素填充布局
self.frm_left.columnconfigure(0, weight=1) # 左侧Frame帧中添加树状视图
tree = ttk.Treeview(self.frm_left, selectmode='browse', show='tree', padding=[0, 0, 0, 0])
tree.grid(row=0, column=0, sticky=tk.NSEW) # 树状视图填充左侧Frame帧
tree.column('#0', width=150) # 设置图标列的宽度,视图的宽度由所有列的宽决定
# 一级节点parent='',index=第几个节点,iid=None则自动生成并返回,text为图标右侧显示文字
# values值与columns给定的值对应
tr_root = tree.insert("", 0, None, open=True, text='播放列表') # 树视图添加根节点
node1 = tree.insert(tr_root, 0, None, open=True, text='本地文件') # 根节点下添加一级节点
node11 = tree.insert(node1, 0, None, text='文件1') # 添加二级节点
node12 = tree.insert(node1, 1, None, text='文件2') # 添加二级节点
node2 = tree.insert(tr_root, 1, None, open=True, text='网络文件') # 根节点下添加一级节点
node21 = tree.insert(node2, 0, None, text='文件1') # 添加二级节点
node22 = tree.insert(node2, 1, None, text='文件2') # 添加二级节点
def initCtrl(self):
'''初始化控制滑块及按钮'''
self.frm_control.columnconfigure(0, weight=1)
# 配置控制区Frame各行列的权重
self.frm_control.rowconfigure(0, weight=1)
# 第一行添加滑动块
self.frm_control.rowconfigure(1, weight=1)
# 第二行添加按钮
slid = ttk.Scale(self.frm_control, from_=0, to=900, command=self.sliderValueChanged)
slid.grid(row=0, column=0, sticky=tk.EW, padx=2) # 滑动块水平方向拉伸
frm_but = ttk.Frame(self.frm_control, padding=2) # 控制区第二行放置按钮及标签
frm_but.grid(row=1, column=0, sticky=tk.EW)
self.lab_curr = ttk.Label(frm_but, text="00:00:00", font=self.ft) # 标签显示当前时间
lab_max = ttk.Label(frm_but, text="00:00:00", font=self.ft) # 标签显示视频长度
self.lab_curr.grid(row=0, column=0, sticky=tk.W, padx=3)
lab_max.grid(row=0, column=13, sticky=tk.E, padx=3)
i = 4
for but in ['播放', '暂停', '快进', '快退', '静音']:
ttk.Button(frm_but, text=but).grid(row=0, column=i)
i += 1
for i in range(14): # 为每列添加权重值以便水平拉伸
frm_but.columnconfigure(i, weight=1)
def sliderValueChanged(self, val):
'''slider改变滑块值的事件'''
#tkinter.messagebox.showinfo("Message", "message")
flt = float(val)
strs = str('%.1f' % flt)
self.lab_curr.config(text=strs)
def initComponent(self, master):
'''初始化GUI组件'''
# 设置顶级窗体的行列权重,否则子组件的拉伸不会填充整个窗体
master.rowconfigure(0, weight=1)
master.columnconfigure(0, weight=1)
self.ft = tkFont.Font(family='微软雅黑', size=12, weight='bold') # 创建字体
# self.initMenu(master) # 为顶级窗体添加菜单项
# 设置继承类MWindow的grid布局位置,并向四个方向拉伸以填充顶级窗体
self.grid(row=0, column=0, sticky=tk.NSEW)
# 设置继承类MWindow的行列权重,保证内建子组件会拉伸填充
self.rowconfigure(0, weight=1)
self.columnconfigure(0, weight=1)
self.panewin = ttk.Panedwindow(self, orient=tk.HORIZONTAL) # 添加水平方向的推拉窗组件
self.panewin.grid(row=0, column=0, sticky=tk.NSEW) # 向四个方向拉伸填满MWindow帧
self.frm_left = ttk.Frame(self.panewin, relief=tk.SUNKEN, padding=0) # 左侧Frame帧用于放置播放列表
self.frm_left.grid(row=0, column=0, sticky=tk.NS) # 左侧Frame帧拉伸填充
self.panewin.add(self.frm_left, weight=1) # 将左侧Frame帧添加到推拉窗控件,左侧权重1
# self.initPlayList() # 添加树状视图
self.frm_right = ttk.Frame(self.panewin, relief=tk.SUNKEN) # 右侧Frame帧用于放置视频区域和控制按钮
self.frm_right.grid(row=0, column=0, sticky=tk.NSEW) # 右侧Frame帧四个方向拉伸
self.frm_right.columnconfigure(0, weight=1) # 右侧Frame帧两行一列,配置列的权重
self.frm_right.rowconfigure(0, weight=8)
# 右侧Frame帧两行的权重8:1
self.frm_right.rowconfigure(1, weight=1)
self.panewin.add(self.frm_right, weight=50) # 将右侧Frame帧添加到推拉窗控件,右侧权重10
s = ttk.Style()
s.configure('www.TFrame', background='black') # 视频区Frame帧添加样式
# 右侧Frame帧第一行添加视频区Frame
self.frm_vedio = ttk.Frame(self.frm_right, relief=tk.RIDGE, style='www.TFrame')
self.frm_vedio.grid(row=0, column=0, sticky=tk.NSEW)
# 右侧Frame帧第二行添加控制按钮
self.frm_control = ttk.Frame(self.frm_right, relief=tk.RAISED) # 四个方向拉伸
self.frm_control.grid(row=1, column=0, sticky=tk.NSEW)
self.initCtrl() # 添加滑块及按钮
if __name__ == "__main__":
root = tk.Tk()
root.geometry('800x480+200+100')
root.title('Media Player')
#root.option_add("*Font", "宋体")
root.minsize(800, 480)
app = MForm(root)
root.mainloop()
1493

被折叠的 条评论
为什么被折叠?



