pyqt5利用pyqtDesigner实现登录界面
作者:窥月 发布时间:2023-09-04 15:19:36
标签:pyqt5,pyqtDesigner,登录
本文实例为大家分享了pyqt5利用pyqtDesigner实现登录界面的具体代码,供大家参考,具体内容如下
为便于操作 界面和逻辑分离
逻辑类:
import sys
import pymysql
from loginUI import * //导入
from PyQt5.QtWidgets import *
from PyQt5 import QtWidgets, QtCore, QtGui
from PyQt5.QtCore import *
from PyQt5.QtGui import
class Login(QtWidgets.QDialog):
def __init__(self):
super(Login, self).__init__()
self.ui = Ui_login_Ui()
self.ui.setupUi(self)
# self.setMinimumSize(QtCore.QSize(400, 200)) # 控制缩放范围
# self.setMaximumSize(QtCore.QSize(400, 200))
self.setWindowTitle("欢迎使用停车场管理系统")
self.setFixedSize(self.width(), self.height())
self.ui.labelTip.hide()
self.ui.labelTip.setText("密码或用户名不能为空!")
# 设置label字体
labelFont = QFont()
labelFont.setPixelSize(15)
# 设置动态背景
self.gif = QMovie('bg2.gif')
self.ui.label_2.setMovie(self.gif)
self.gif.start()
# 这在label属性
self.ui.labelTip.setStyleSheet(
"QLabel{color:red;font-size:12px;font-weight:bold;font-family:Roman times;}"
)
self.ui.userLabel.setStyleSheet("QLabel{background:white;}"
"QLabel{color:rgb(100,100,100,250);font-size:15px;font-weight:bold;font-family:Roman times;}"
"QLabel:hover{color:rgb(300,300,300,120);}")
self.ui.pwdlabel.setStyleSheet("QLabel{background:white;}"
"QLabel{color:rgb(100,100,100,250);font-size:15px;font-weight:bold;font-family:Roman times;}"
"QLabel:hover{color:rgb(300,300,300,120);}")
self.ui.label.setStyleSheet("QLabel{background:white;}"
"QLabel{color:rgb(100,100,100,250);font-size:15px;font-weight:bold;font-family:Roman times;}"
"QLabel:hover{color:rgb(300,300,300,120);}")
self.ui.loginButton.setStyleSheet("QPushButton{color:black}"
"QPushButton:hover{color:red}"
"QPushButton{background-color:lightblue}"
"QPushButton{border:2px}"
"QPushButton{border-radius:10px}"
"QPushButton{padding:2px 4px}")
self.ui.registerButton.setStyleSheet("QPushButton{color:black}"
"QPushButton:hover{color:red}"
"QPushButton{background-color:lightgreen}"
"QPushButton{border:2px}"
"QPushButton{border-radius:10px}"
"QPushButton{padding:2px 4px}")
palette = QPalette()
icon = QPixmap('bg2.gif').scaled(800, 600)
palette.setBrush(self.backgroundRole(), QBrush(icon))
self.setPalette(palette)
self.ui.userLabel.setFont(labelFont)
self.ui.pwdlabel.setFont(labelFont)
self.ui.label.setFont(labelFont)
# 设置控件尺寸
# self.ui.userlineEdit.setFrame(False)
# self.ui.pwdlineEdit.setFrame(False)
self.ui.pwdlineEdit.setEchoMode(QLineEdit.Password)# 输入框设为密码模式
self.ui.pwdlineEdit.setClearButtonEnabled(True)
self.ui.userlineEdit.setClearButtonEnabled(True)
self.ui.userlineEdit.setFixedWidth(190)
self.ui.userlineEdit.setFixedHeight(30)
self.ui.pwdlineEdit.setFixedWidth(190)
self.ui.pwdlineEdit.setFixedHeight(30)
self.ui.comboBox.setFixedWidth(100)
self.ui.comboBox.setFixedHeight(28)
self.ui.loginButton.setFixedSize(75, 28)
self.ui.registerButton.setFixedSize(75, 28)
self.ui.loginButton.setShortcut('Enter') # shortcut key
# 登陆的槽函数登陆按钮 最好写在init的析构函数中,避免链接多次产生异常
self.ui.loginButton.clicked.connect(self.slotLogin)
self.ui.registerButton.clicked.connect(self.slotRegister)
self.ui.pushButton.clicked.connect(self.findPwd)
name = self.ui.userlineEdit.text()
pwd = self.ui.pwdlineEdit.text()
identity = self.ui.comboBox.currentIndex()
identity = str(identity)
sql = "select * from administrater where username = '" + name + "' and password = '" + pwd + "' and identity= '"+ identity +"' "
db = PyMySQLHelper()
db.selectALL(sql)
def keyPressEvent(self, event):
if event.key() == QtCore.Qt.Key_Enter:
self.slotLogin()
def findPwd(self):
# self.accept()
self.u = FPwd_ui()
self.u.show()
# self.ui.exec()
def slotLogin(self):
# # 获得登录输入
name = self.ui.userlineEdit.text()
pwd = self.ui.pwdlineEdit.text()
print(name)
db = PyMySQLHelper()
identity = self.ui.comboBox.currentIndex() # 获取下标
identity = str(identity)
if name != '' and pwd != '':
if identity == '0':
sql = "select * from administrater where username = '" + name + "' and " \
"password = '" + pwd + "' and identity= '" + identity + "' "
print(sql)
# cursor.execute(sql)
# results = cursor.fetchall()
results = db.selectALL(sql)
if results:
self.ui1 = Finance()
# self.ui1.exec()
self.ui1.show()
self.close()
else:
OK = QMessageBox.warning(self, ("警告"), ("""账号或密码错误!"""))
# cursor.close()
# conn.close()
elif identity == '1':
sql = "select * from administrater where username = '" + name + "' and " \
"password = '" + pwd + "' and identity= '" + identity + "' "
print(sql)
# cursor.execute(sql)
# results = cursor.fetchall()
results = db.selectALL(sql)
if results:
self.ui2 = InfoManage()
self.ui2.show()
self.close()
else:
OK = QMessageBox.warning(self, ("警告"), ("""账号或密码错误!"""))
elif identity == '2':
sql = "select * from administrater where username = '" + name + "' and " \
"password = '" + pwd + "' and identity= '" + identity + "' "
print(sql)
results = db.selectALL(sql)
# print(identity)
if results:
self.uu = SeatManage()
self.uu.exec()
self.close()
else:
OK = QMessageBox.warning(self, ("警告"), ("""账号或密码错误!"""))
elif name == 'admin' and pwd == '123' and identity == '3':
self.a = Admin()
self.a.show()
self.close()
else:
if name == '':
OK = QMessageBox.warning(self, ("警告"), ("""请输入账号!"""))
if pwd == '':
OK = QMessageBox.warning(self, ("警告"), ("""请输入密码!"""))
# cursor.close()
# conn.close()
def slotRegister(self):
self.i = reUi() # self.i的窗口命名不能重复
self.i.exec_()
if __name__ == '__main__':
app = QtWidgets.QApplication(sys.argv)
my = Login()
my.show()
sys.exit(app.exec_())
界面类:
from PyQt5 import QtCore, QtGui, QtWidgets
class Ui_login_Ui(object):
def setupUi(self, login_Ui):
login_Ui.setObjectName("login_Ui")
login_Ui.resize(581, 533)
self.gridLayoutWidget = QtWidgets.QWidget(login_Ui)
self.gridLayoutWidget.setGeometry(QtCore.QRect(160, 330, 295, 141))
self.gridLayoutWidget.setObjectName("gridLayoutWidget")
self.gridLayout = QtWidgets.QGridLayout(self.gridLayoutWidget)
self.gridLayout.setContentsMargins(0, 0, 0, 0)
self.gridLayout.setObjectName("gridLayout")
self.horizontalLayout_2 = QtWidgets.QHBoxLayout()
self.horizontalLayout_2.setObjectName("horizontalLayout_2")
self.loginButton = QtWidgets.QPushButton(self.gridLayoutWidget)
self.loginButton.setObjectName("loginButton")
self.horizontalLayout_2.addWidget(self.loginButton)
self.registerButton = QtWidgets.QPushButton(self.gridLayoutWidget)
self.registerButton.setObjectName("registerButton")
self.horizontalLayout_2.addWidget(self.registerButton)
self.pushButton = QtWidgets.QPushButton(self.gridLayoutWidget)
self.pushButton.setObjectName("pushButton")
self.horizontalLayout_2.addWidget(self.pushButton)
self.gridLayout.addLayout(self.horizontalLayout_2, 4, 1, 1, 1)
self.userlineEdit = QtWidgets.QLineEdit(self.gridLayoutWidget)
self.userlineEdit.setObjectName("userlineEdit")
self.gridLayout.addWidget(self.userlineEdit, 0, 1, 1, 1)
self.userLabel = QtWidgets.QLabel(self.gridLayoutWidget)
self.userLabel.setObjectName("userLabel")
self.gridLayout.addWidget(self.userLabel, 0, 0, 1, 1)
self.labelTip = QtWidgets.QLabel(self.gridLayoutWidget)
self.labelTip.setObjectName("labelTip")
self.gridLayout.addWidget(self.labelTip, 3, 1, 1, 1)
self.pwdlineEdit = QtWidgets.QLineEdit(self.gridLayoutWidget)
self.pwdlineEdit.setObjectName("pwdlineEdit")
self.gridLayout.addWidget(self.pwdlineEdit, 1, 1, 1, 1)
self.pwdlabel = QtWidgets.QLabel(self.gridLayoutWidget)
self.pwdlabel.setObjectName("pwdlabel")
self.gridLayout.addWidget(self.pwdlabel, 1, 0, 1, 1)
self.comboBox = QtWidgets.QComboBox(self.gridLayoutWidget)
self.comboBox.setObjectName("comboBox")
self.comboBox.addItem("")
self.comboBox.addItem("")
self.comboBox.addItem("")
self.comboBox.addItem("")
self.gridLayout.addWidget(self.comboBox, 2, 1, 1, 1)
self.label = QtWidgets.QLabel(self.gridLayoutWidget)
self.label.setObjectName("label")
self.gridLayout.addWidget(self.label, 2, 0, 1, 1)
self.label_2 = QtWidgets.QLabel(login_Ui)
self.label_2.setGeometry(QtCore.QRect(-10, 0, 601, 321))
self.label_2.setText("")
self.label_2.setObjectName("label_2")
self.retranslateUi(login_Ui)
QtCore.QMetaObject.connectSlotsByName(login_Ui)
def retranslateUi(self, login_Ui):
_translate = QtCore.QCoreApplication.translate
login_Ui.setWindowTitle(_translate("login_Ui", "Form"))
self.loginButton.setText(_translate("login_Ui", "登 陆"))
self.registerButton.setText(_translate("login_Ui", "注 册"))
self.pushButton.setText(_translate("login_Ui", "找回密码"))
self.userLabel.setText(_translate("login_Ui", " 账 户"))
self.labelTip.setText(_translate("login_Ui", "密码或用户名错误"))
self.pwdlabel.setText(_translate("login_Ui", " 密 码"))
self.comboBox.setItemText(0, _translate("login_Ui", "财务管理员"))
self.comboBox.setItemText(1, _translate("login_Ui", "信息管理员"))
self.comboBox.setItemText(2, _translate("login_Ui", "停车场管理员"))
self.comboBox.setItemText(3, _translate("login_Ui", "超级管理员"))
self.label.setText(_translate("login_Ui", " 请选择"))
具体代码:pyqt5实现登录界面
来源:https://blog.csdn.net/qq_32973061/article/details/81749982


猜你喜欢
- 解决SQL Server 连接失败的问题最近因学习数据库系统原理,下载安装了一个2019版本的,启动服务后,发现使用Aqua Data St
- 代码很简单,这里就不多BB了,小伙伴们直接看示例吧<!DOCTYPE html PUBLIC "-//W3C//DTD XH
- 本文实例为大家分享了python实现比较文件内容异同的具体代码,供大家参考,具体内容如下import sysimport difflibim
- 在VS2005装完后,会自带SQL Server2005 express版,为了便于管理,还需要安装一个企业管理器,需要下载 Microso
- 使用Tensorflow进行深度学习训练的时候,需要对训练好的网络模型和各种参数进行保存,以便在此基础上继续训练或者使用。介绍这方面的博客有
- 本文需要一点Python socket基础。回顾RPC客户端(Client):服务调用方。客户端存根(Client Stub):存放服务端地
- 一、下载安装官网下载社区版dmg安装文件: https://dev.mysql.com/downloads/mysql/1、执行安装文件,按
- 一、TCP1、tcp服务器创建#创建服务器from socket import *from time import ctime #导入cti
- 声明定位元素:position属性值设置除默认值static以外的元素,包括relative,absolute,fixed。平台:win/I
- 实验室导师又有任务,从一个.dat文件中读取波形数据,通过一个自编码网络进行异常检测。可是对我这种小白来说真的艰难。从最基础的文件读写开始吧
- Mysql 中数据是要落盘的,这点大家都知道。读写磁盘速度是很慢的,尤其和内存比起来更是没的说。但是,我们平时在执行 SQL 时,无论写操作
- 最近感觉被大数据定义成机器人了,随便看个网页都跳验证码。怎么用python绕验证码是个令人头秃的事情,我投降!那么今天手把手教大家如何写验证
- Python 正则表达式简介正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配。Python 自1.5版本起增
- 下面就来说说解决方案吧~import osimport syscurPath = os.path.abspath(os.path.dirna
- 加载静态文件在一个网页中,不仅仅只有一个 html 骨架,还需要 css 样式文件, js 执行文件以及一些图片等。因此在 DTL 中加载静
- 1、先放个大招:去除字符串中所有的空格和tab换行符str=" a b c de f "pri
- 学习Go语言的一些感受,不一定准确。假如发生战争,JAVA一般都是充当航母战斗群的角色。一旦出动,就是护卫舰、巡洋舰、航母舰载机、预警机、电
- 使用PHP开发应用程序,尤其是网站程序,常常需要生成随机密码,如用户注册生成随机密码,用户重置密码也需要生成一个随机的密码。随机密码也就是一
- 一、聚合函数聚合函数:又叫组函数,用来对表中的数据进行统计和计算,结合group by分组使用,用于统计和计算分组数据常用聚合函数count
- python3 manage.py makemigrations # 生成数据库迁移文件python3 manage.py migrate