怎么在wxpython中使用pymysql实现一个用户登陆功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
#设置窗口的左上角的图标
#其中参数type表示图片的类型,还有ico,jpgm等类型
icon_1 = wx.Icon(name='python1.png',type=wx.BITMAP_TYPE_PNG)
frame.SetIcon(icon_1)
在panel中添加图片展示:
panel = wx.Panel(frame,-1)
# 向panel中添加图片
image =wx.Image("python2.jpg", wx.BITMAP_TYPE_JPEG).ConvertToBitmap()
wx.StaticBitmap(panel, -1, bitmap=image, pos=(0, 0))
给登陆按钮设计点击函数:
本次没有使用图片按钮,只是简单的按钮插件,所以看起来比较丑
#添加按钮,pos参数为其位置
self.but_login = wx.Button(panel,-1,"登陆", size=(120,50), pos=(120,300))
self.but_register = wx.Button(panel,-1,"注册", size=(120,50), pos=(260,300))
#设置按钮的颜色
self.but_login.SetBackgroundColour("#0a74f7")
self.but_register.SetBackgroundColour("#282c34")
#给按钮绑定事件
self.Bind(wx.EVT_BUTTON,self.on_but_login,self.but_login)
self.Bind(wx.EVT_BUTTON,self.on_but_register,self.but_register)
如果要设计图片按钮可以这样实现:
#设置图片按钮
pic = wx.Image('but_log.png', wx.BITMAP_TYPE_PNG).ConvertToBitmap() # 把这个图片的内容妆转化为这个pic 变量。
#pos为位置参数,设置按钮放置的位置
self.button = wx.BitmapButton(panel, -1, pic, pos=(10, 10)) # 固定的写法使用
效果如下:
pymysql连接本地数据库,与用户输入对比:
通过getValue()的方法获取用户的输入内容,然后连接数据库经行查找和比较;
#定义一个消息弹出框的函数
def show_message(self,word=""):
dlg = wx.MessageDialog(None, word, u"错误", wx.YES_NO | wx.ICON_QUESTION)
if dlg.ShowModal() == wx.ID_YES:
#self.Close(True)
pass
dlg.Destroy()
def on_but_login(self,event):
#连接到本地数据库
user_name = self.entry_user.GetValue()
pass_word= self.entry_pass.GetValue()
sql = """select pass from student where name ='%s' """ % (user_name)
#判断,查看用户名和密码名是否为空
#不为空之后在进行查询和判断
#不然当密码或用户名为空时会出现会导致出错
if user_name and pass_word:
db = pymysql.connect(host="localhost", user="root",
password="zhang123", db="user", port=3306)
# 使用cursor()方法获取操作游标
cur = db.cursor()
try:
cur.execute(sql) # 执行sql语句
results = cur.fetchall() # 获取查询的所有记录
#返回值是一个元组的形式
#print(type(results))
if results:
#print(type(results[0][0]))
#print(results[0][0])
if results[0][0] == pass_word:
#表示登陆成功,后续可以写登陆成功后的界面
#此处就不再写
pass
#print("sucessful")
else:
self.show_message(word="密码错误")
else:
self.show_message(word='用户名不存在')
except Exception as e:
db.rollback()
finally:
db.close() # 关闭连接
else:
self.show_message(word='账号和密码不能为空')
总之,由于本人对布局掌握的不是很好,用的时固定坐标的方法,导致当窗口进行拉升的时候效果不是很好:
案例的整体源代码:
大家只要将需要加载的图片资源和代码放在同一个文件下就可以运行了:
import wx
import pymysql
#由于当前对布局管理器不是很熟悉,所系使用的是固定位置,导致窗口拉伸的效果不是很好
class MyApp(wx.App):
def __init__(self):
wx.App.__init__(self)
frame = wx.Frame(parent=None,title='Login',size=(532,420))
#设置窗口的左上角的图标
#其中参数type表示图片的类型,还有ico,jpgm等类型
icon_1 = wx.Icon(name='python1.png',type=wx.BITMAP_TYPE_PNG)
frame.SetIcon(icon_1)
panel = wx.Panel(frame,-1)
# 向panel中添加图片
image =wx.Image("python2.jpg", wx.BITMAP_TYPE_JPEG).ConvertToBitmap()
wx.StaticBitmap(panel, -1, bitmap=image, pos=(0, 0))
#添加静态标签
label_user = wx.StaticText(panel,-1,"账号:", pos=(80,200))
label_pass = wx.StaticText(panel,-1,"密码:", pos=(80,240))
#添加文本输入框
self.entry_user = wx.TextCtrl(panel,-1,size=(200,30), pos=(130,200))
#style 为设置输入
self.entry_pass = wx.TextCtrl(panel,-1, size=(200,30), pos=(130,240), style=wx.TE_PASSWORD)
#添加按钮
self.but_login = wx.Button(panel,-1,"登陆", size=(120,50), pos=(120,300))
self.but_register = wx.Button(panel,-1,"注册", size=(120,50), pos=(260,300))
#设置按钮的颜色
self.but_login.SetBackgroundColour("#0a74f7")
self.but_register.SetBackgroundColour("#282c34")
#给按钮绑定事件
self.Bind(wx.EVT_BUTTON,self.on_but_login,self.but_login)
self.Bind(wx.EVT_BUTTON,self.on_but_register,self.but_register)
#
frame.Center()
frame.Show(True)
#定义一个消息弹出框的函数
def show_message(self,word=""):
dlg = wx.MessageDialog(None, word, u"错误", wx.YES_NO | wx.ICON_QUESTION)
if dlg.ShowModal() == wx.ID_YES:
#self.Close(True)
pass
dlg.Destroy()
def on_but_login(self,event):
#连接到本地数据库
user_name = self.entry_user.GetValue()
pass_word= self.entry_pass.GetValue()
sql = """select pass from student where name ='%s' """ % (user_name)
#判断,查看用户名和密码名是否为空
#不为空之后在进行查询和判断
#不然当密码或用户名为空时会出现会导致出错
if user_name and pass_word:
db = pymysql.connect(host="localhost", user="root",
password="zhang123", db="user", port=3306)
# 使用cursor()方法获取操作游标
cur = db.cursor()
try:
cur.execute(sql) # 执行sql语句
results = cur.fetchall() # 获取查询的所有记录
#返回值是一个元组的形式
#print(type(results))
if results:
#print(type(results[0][0]))
#print(results[0][0])
if results[0][0] == pass_word:
#表示登陆成功,后续可以写登陆成功后的界面
#此处就不再写
pass
#print("sucessful")
else:
self.show_message(word="密码错误")
else:
self.show_message(word='用户名不存在')
except Exception as e:
db.rollback()
finally:
db.close() # 关闭连接
else:
self.show_message(word='账号和密码不能为空')
def on_but_register(self,event):
#类似上上面的查询,只需获取相关内容插入到数据库就可以做出相关的操作
#内容与上面内容相似,不再经行书写
pass
if __name__=='__main__':
app = MyApp()
app.MainLoop()
看完上述内容,你们掌握怎么在wxpython中使用pymysql实现一个用户登陆功能的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
亿速云「云数据库 MySQL」免部署即开即用,比自行安装部署数据库高出1倍以上的性能,双节点冗余防止单节点故障,数据自动定期备份随时恢复。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。