【项目实战】基于Python+PyQt5+MySQL的GUI学生管理系统(附完整源码)
1、项目说明
基于python+PyQt5+MySQL的学生管理系统项目实战
项目需要安装pycharm社区版或专业版都可,以及项目所需的所有模块
项目需要安装PyQt5及其他一些模块(详见项目所需模块文件夹)
安装命令如下:
- pip install -i https://pypi.tuna.tsinghua.edu.cn/simple 模块名称
- 如安装PyQt5:pip install -i https://pypi.tuna.tsinghua.edu.cn/simple pyqt5
项目打包为exe文件需要安装pyinstaller
执行命令:pyinstaller -F -w main.py -i logo图片的地址
2、项目主要技术
-
python编程技术
-
pyqt5界面编程
-
mysql数据库技术
3、项目结构
-
data 存放导入导出的数据的文件夹
-
image 存放背景图片的文件夹
-
AddAdmin.py 添加用户的界面的设计代码
-
ComboCheckBox.py 添加或者修改用户信息的时候的选择框工具代码
-
Config.py 配置文件存放项目常量参数
-
db.py 数据库链接代码
-
EditAdmin.py 修改用户的界面的设计代码
-
login.py 项目的入口(登录界面和功能的实现)
-
mian.py 程序主界面设计与功能实现代码
-
sqls.py 存放操作数据库的sql语句代码
4、项目主要功能
-
老师与管理员的登录验证
-
学生管理
-
成绩管理
-
班级管理
-
用户信息管理
5、部分源码
login.py
"""
项目名称:python pyqt5 mysql 学生管理系统
作者:bhml
时间:2022/11/28
代码功能:一、登录界面与功能实现
"""
import sys
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtWidgets import QApplication, QMainWindow
from main import MainUi
from sqls import *
from db import *
import Config as C
# 界面与登录功能的设计与实现
class Ui_MainWindow(object):
def setupUi(self, MainWindow):
MainWindow.setObjectName("MainWindow")
MainWindow.resize(400, 400)
self.centralwidget = QtWidgets.QWidget(MainWindow)
self.centralwidget.setObjectName("centralwidget")
self.label = QtWidgets.QLabel(self.centralwidget)
self.label.setGeometry(QtCore.QRect(30, 30, 350, 60))
sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.Preferred, QtWidgets.QSizePolicy.Preferred)
sizePolicy.setHorizontalStretch(0)
sizePolicy.setVerticalStretch(0)
sizePolicy.setHeightForWidth(self.label.sizePolicy().hasHeightForWidth())
self.label.setSizePolicy(sizePolicy)
self.label.setMinimumSize(QtCore.QSize(50, 50))
self.label.setBaseSize(QtCore.QSize(50, 50))
font = QtGui.QFont()
font.setFamily("楷体")
font.setPointSize(27)
font.setBold(True)
font.setItalic(False)
font.setWeight(75)
self.label.setFont(font)
self.label.setLayoutDirection(QtCore.Qt.LeftToRight)
self.label.setAutoFillBackground(False)
self.label.setMidLineWidth(0)
self.label.setAlignment(QtCore.Qt.AlignCenter)
self.label.setWordWrap(False)
self.label.setIndent(0)
self.label.setObjectName("label")
self.lineEdit = QtWidgets.QLineEdit(self.centralwidget)
self.lineEdit.setGeometry(QtCore.QRect(140, 140, 181, 31))
font = QtGui.QFont("Microsoft YaHei")
font.setPointSize(11)
self.lineEdit.setFont(font)
self.lineEdit.setInputMask("")
self.lineEdit.setText("")
self.lineEdit.setObjectName("lineEdit")
self.label_2 = QtWidgets.QLabel(self.centralwidget)
self.label_2.setGeometry(QtCore.QRect(40, 140, 91, 31))
font = QtGui.QFont("Microsoft YaHei")
font.setPointSize(11)
self.label_2.setFont(font)
self.label_2.setAlignment(QtCore.Qt.AlignRight | QtCore.Qt.AlignTrailing | QtCore.Qt.AlignVCenter)
self.label_2.setObjectName("label_2")
self.label_3 = QtWidgets.QLabel(self.centralwidget)
self.label_3.setGeometry(QtCore.QRect(40, 190, 91, 31))
font = QtGui.QFont("Microsoft YaHei")
font.setPointSize(11)
self.label_3.setFont(font)
self.label_3.setAlignment(QtCore.Qt.AlignRight | QtCore.Qt.AlignTrailing | QtCore.Qt.AlignVCenter)
self.label_3.setObjectName("label_3")
self.lineEdit_2 = QtWidgets.QLineEdit(self.centralwidget)
self.lineEdit_2.setGeometry(QtCore.QRect(140, 190, 181, 31))
font = QtGui.QFont("Microsoft YaHei")
font.setPointSize(11)
self.lineEdit_2.setFont(font)
self.lineEdit_2.setInputMask("")
self.lineEdit_2.setText("")
self.lineEdit_2.setEchoMode(QtWidgets.QLineEdit.Password)
self.lineEdit_2.setObjectName("lineEdit_2")
self.pushButton = QtWidgets.QPushButton(self.centralwidget)
self.pushButton.setGeometry(QtCore.QRect(120, 280, 160, 40))
font = QtGui.QFont("Microsoft YaHei")
font.setPointSize(16)
self.pushButton.setFont(font)
self.pushButton.setObjectName("pushButton")
font = QtGui.QFont("Microsoft YaHei")
font.setItalic(False)
font.setPointSize(14)
self.label_6 = QtWidgets.QLabel(self.centralwidget)
self.label_6.setGeometry(QtCore.QRect(80, 240, 250, 20))
self.label_6.setObjectName("label_6")
self.label_6.setFont(font)
MainWindow.setCentralWidget(self.centralwidget)
self.menubar = QtWidgets.QMenuBar(MainWindow)
self.menubar.setGeometry(QtCore.QRect(0, 0, 640, 23))
self.menubar.setObjectName("menubar")
MainWindow.setMenuBar(self.menubar)
self.statusbar = QtWidgets.QStatusBar(MainWindow)
self.statusbar.setObjectName("statusbar")
MainWindow.setStatusBar(self.statusbar)
self.retranslateUi(MainWindow)
QtCore.QMetaObject.connectSlotsByName(MainWindow)
self.centralwidget.setStyleSheet('''
QLabel#label_6{
color:red;
}
#pushButton{background-color:#2c7adf;color:#fff;border:none;border-radius:4px;}
#pushButton:hover{background-color:#2c8adf;}
''')
self.pushButton.clicked.connect(lambda: self.btn_clicked(MainWindow))
def retranslateUi(self, MainWindow):
_translate = QtCore.QCoreApplication.translate
MainWindow.setWindowTitle(_translate("MainWindow", "Python学生管理系统-管理员登录"))
self.label.setText(_translate("MainWindow", "Python学生管理系统"))
self.lineEdit.setPlaceholderText(_translate("MainWindow", "请输入用户名"))
self.label_2.setText(_translate("MainWindow", "用户名:"))
self.label_3.setText(_translate("MainWindow", "密码:"))
self.lineEdit_2.setPlaceholderText(_translate("MainWindow", "请输入密码"))
self.pushButton.setText(_translate("MainWindow", "登录"))
# 管理员登录
def btn_clicked(self, MainWindow):
self.label_6.setText("正在登录...")
self.pushButton.setDisabled(True)
QApplication.processEvents()
username = self.lineEdit.text()
password = self.lineEdit_2.text()
result = sql_execute(login(username, password))
if len(result) == 0:
self.label_6.setText("登录失败:用户名或密码错误")
self.pushButton.setDisabled(False)
print(username + "登录失败!")
else:
print(username + "登录成功!")
self.label_6.setText("登录成功!")
print(result[0])
C.USER = result[0]
self.main = MainUi()
self.main.show()
C.LOGIN_WINDOW = aw
MainWindow.hide()
self.main.setWindowTitle('Python学生管理系统')
if __name__ == "__main__":
App = QApplication(sys.argv) # 创建QApplication对象,作为GUI主程序入口
aw = Ui_MainWindow() # 创建主窗体对象,实例化Ui_MainWindow
w = QMainWindow() # 实例化QMainWindow类
aw.setupUi(w) # 主窗体对象调用setupUi方法,对QMainWindow对象进行设置
w.show() # 显示主窗体
w.setWindowTitle('Python学生管理系统-管理员登录')
sys.exit(App.exec_()) # 循环中等待退出程序
6、运行截图
7、项目总结
本项目是一个非常适合练手的项目,对我们的python编程技术结合pyqt5模块运用开发界面的提升有很大的帮助,推荐大家学习研究这个项目,搞懂其中的业务逻辑流程以及各个知识点非常关键。
项目资料截图:
资料获取地址:https://h5.m.taobao.com/awp/core/detail.htm?ft=t&id=700080218561
B站视频讲解地址:https://www.bilibili.com/video/BV18j411T79e/
注:其他问题请参看视频讲解,都有介绍,一定要认真看完哦!
代码编写、视频录制不易,感谢您的支持,祝您学习愉快!
避免走丢,记得关注哦🌹🌹🌹
版权声明:本文为博主兵慌码乱原创文章,请勿转载!