教你用Python制作一个NBA球员数据查询小程序

2023-11-24 20:50

本文主要是介绍教你用Python制作一个NBA球员数据查询小程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理。

以下文章来源于早起Python ,作者投稿君

一、前言

有时将代码转成带有界面的程序,会极大地方便使用,虽然在网上有很多现成的GUI系统,但是套用别人的代码,心里难免有些尴尬,所以本文将用Python爬虫结合wxpython模块构造一个NBA爬虫小软件

 

 

本文框架构造将分为二个部分讲解:

  1. 构建GUI界面
  2. 举例套用爬虫框架

主要涉及的Python模块有

  • requests
  • wx
  • pymysql
  • pandas

 

二、GUI界面设计

首先介绍下流程:GUI界面设计讲解插入界面背景图片

设计GUI界面的代码思路其实很简单,首先导入wx库

import wx

这里引用的模块是wxpython模块,建立GUI的模块很多,常见的有PyQt、Tkinter等。这些模块各有各的优缺点,读者可以翻阅相关资料进行选择。

class MyFrame(wx.Frame):def __init__(self, parent, id):wx.Frame.__init__(self, parent, id, 'titlename',size=(400, 300))panel = wx.Panel(self)self.bt_confirm = wx.Button(panel, label='name1')self.bt_confirm.Bind(wx.EVT_BUTTON,self.OnclickSubmit)self.bt_cancel = wx.Button(panel, label='name2')self.bt_cancel.Bind(wx.EVT_BUTTON,self.OnclickCancel)self.InitUI()

定义全局变量对于初级的GUI来说就是构建一个形式窗口+按钮布置,不需要自建一个模块。但对于高级的GUI诸如投资系统而言,全局变量是尤为重要的,换句话说全局变量需要放在一个py文件中初始化。

上述代码是创建部分的代码,个性化布局需要添加容器进行设置,稍后会在总代码中呈现。

def InitUI(self):""" 点击InitUI,执行方法 """def OnclickSubmit(self,event):""" 绑定OnclickSubmit事件 """

简单来说就是绑定事件,该事件是你点击对应按钮产生的效果。这部是整个GUI的核心,如果你在做签到系统,那么你就要绑定一个导入员工名单txt文件的事件。

if __name__ == '__main__':app = wx.App()                      # 初始化frame = MyFrame(parent=None,id=-1)   frame.Show()                        app.MainLoop()                      # 调用主循环
del app

第四步的基本套路就是如此。

三、举例实现

以一个简单的NBA爬虫系统为例,首先创建面板与布局

class MyFrame(wx.Frame):def __init__(self, parent, id):wx.Frame.__init__(self, parent, id, 'NBA可视化',size=(400, 300))panel = wx.Panel(self)self.bt_confirm = wx.Button(panel, label='合同信息')self.bt_confirm.Bind(wx.EVT_BUTTON,self.OnclickSubmit)self.bt_cancel = wx.Button(panel, label='清空')self.bt_cancel.Bind(wx.EVT_BUTTON,self.OnclickCancel)self.bt_imf = wx.Button(panel, label='可视化')self.bt_imf.Bind(wx.EVT_BUTTON,self.Onclickvisual)self.bt_team = wx.Button(panel, label='球队信息',pos=(280,20))self.bt_team.Bind(wx.EVT_BUTTON,self.Onclickteam)self.bt_obtain = wx.Button(panel, label='球员信息',pos=(20,20))self.bt_obtain.Bind(wx.EVT_BUTTON,self.Onclickimfor)self.bt_ml = wx.Button(panel, label='得分榜')self.bt_ml.Bind(wx.EVT_BUTTON,self.Onclickmql)     self.title = wx.StaticText(panel, label="NBA可视化")self.label_user = wx.StaticText(panel, label="球队名称")self.text_user = wx.TextCtrl(panel, style=wx.TE_LEFT)self.label_pwd = wx.StaticText(panel, label="球员名称")self.text_pwd = wx.TextCtrl(panel, style=wx.TE_LEFT)self.label_path = wx.StaticText(panel, label="储存路径")self.text_pathword = wx.TextCtrl(panel, style=wx.TE_LEFT)

然后添加容器,横向排列

   hsizer_user = wx.BoxSizer(wx.HORIZONTAL)hsizer_user.Add(self.label_user, proportion=0, flag=wx.ALL, border=5)hsizer_user.Add(self.text_user, proportion=1, flag=wx.ALL, border=5)hsizer_pwd = wx.BoxSizer(wx.HORIZONTAL)hsizer_pwd.Add(self.label_pwd, proportion=0, flag=wx.ALL, border=5)hsizer_pwd.Add(self.text_pwd, proportion=1, flag=wx.ALL, border=5)        hsizer_path = wx.BoxSizer(wx.HORIZONTAL)hsizer_path.Add(self.label_path, proportion=0, flag=wx.ALL, border=5)hsizer_path.Add(self.text_pathword, proportion=1, flag=wx.ALL, border=5)       hsizer_button = wx.BoxSizer(wx.HORIZONTAL)hsizer_button.Add(self.bt_confirm, proportion=0, flag=wx.ALIGN_CENTER, border=5)hsizer_button.Add(self.bt_cancel, proportion=0, flag=wx.ALIGN_CENTER, border=5)hsizer_button.Add(self.bt_imf, proportion=0, flag=wx.ALIGN_CENTER, border=5)hsizer_button.Add(self.bt_ml, proportion=0, flag=wx.ALIGN_CENTER, border=5)       

接着添加容器,纵向排列

        vsizer_all = wx.BoxSizer(wx.VERTICAL)vsizer_all.Add(self.title, proportion=0, flag=wx.BOTTOM | wx.TOP | wx.ALIGN_CENTER,border=15)vsizer_all.Add(hsizer_user, proportion=0, flag=wx.EXPAND | wx.LEFT | wx.RIGHT, border=45)vsizer_all.Add(hsizer_pwd, proportion=0, flag=wx.EXPAND | wx.LEFT | wx.RIGHT, border=45)vsizer_all.Add(hsizer_path, proportion=0, flag=wx.EXPAND | wx.LEFT | wx.RIGHT, border=45)      vsizer_all.Add(hsizer_button, proportion=0, flag=wx.ALIGN_CENTER | wx.TOP, border=15)panel.SetSizer(vsizer_all)self.InitUI()

下一步是事件绑定

    def InitUI(self):""" 点击使用说明按钮,执行方法 """        def OnQuit1(self,e):""" 输入注意事项 """def OnclickSubmit(self,event):""" 点击合同信息按钮,执行方法 """def Onclickvisual(self,event):""" 点击可视化按钮,执行方法 """def OnclickCancel(self,event):""" 点击清空按钮,执行方法 """ def Onclickimfor(self,event):""" 点击球员名称按钮,执行方法 """ def Onclickteam(self,event):""" 点击球队名称按钮,执行方法 """ def Onclickmql(self,event):""" 点击得分榜按钮,执行方法 """

这里的事件处理不是很难,读者可以自己尝试创新,最后执行脚本

if __name__ == '__main__':app = wx.App()                      # 初始化frame = MyFrame(parent=None,id=-1)  # 实例MyFrame类,并传递参数 frame.Show()                        # 显示窗口app.MainLoop()                      # 调用主循环方法

效果如图

 

补充:插入背景图片

想要构造一个个性化系统,最不能缺的就是将界面背景换成自己想要的。这里我选择用一张老科的图片。

相信有的读者会觉得一个独立的单机的GUI软件会更适合自己,我也恰恰如此,因此,在设置背景图片中于之后的GUI需要进行打包,故需要将指定的二进制图片base64化,转换后存入py文件后以import为媒介才能打包。二进制代码转换如下:

import base64
with open("name.jpg","rb") as f:  base64_str = base64.b64encode(f.read())  
with open('%s.py' % picture_name.replace('.', '_'), 'w+') as f1:f1.write(base64_str)f1.close()  

此时可以得到有base64编码的py文件,而后在代码中进行引用。由于打包不能打包图片,故这里稍微复杂的实现“引用指定图片的base64编码——创建图片——插入背景图片”功能!

最后再稍加修饰将文本底色改为透明。编写这段代码的框架非常固定,所以我借鉴了大神们的代码,基本代码框架如下:

#这里需要在主事件中插入两句话
panel.Bind(wx.EVT_ERASE_BACKGROUND,self.OnEraseBack)
self.Bind(wx.EVT_ERASE_BACKGROUND, self.OnEraseBack)
#引用编码并创建图片
from bg_png import img as bg    
def pic(picPath,picName):tmp = open(picPath, 'wb')        tmp.write(base64.b64decode(picName))   tmp.close()      
pic('bg.png',bg)
#插入图片(子事件 有缩进)def OnEraseBack(self,event):'''加入图片背景'''try :dc = event.GetDC()if not dc:dc = wx.ClientDC(self)rect = self.GetUpdateRegion().GetBox()dc.SetClippingRect(rect)dc.Clear()bmp = wx.Bitmap(nowpath+r'\bg.png')dc.DrawBitmap(bmp, -500, -100)except :pass
#将文本底色改为透明
#第一步:将主事件中wx.StaticText全部换成TransparentStaticText
#第二步:重现StaticText控件
class TransparentStaticText(wx.StaticText):def __init__(self, parent, id=wx.ID_ANY, label='', pos=wx.DefaultPosition, size=wx.DefaultSize,style=wx.TRANSPARENT_WINDOW, name='TransparentStaticText'):wx.StaticText.__init__(self, parent, id, label, pos, size, style, name)self.Bind(wx.EVT_PAINT, self.OnPaint)self.Bind(wx.EVT_ERASE_BACKGROUND, lambda event: None)self.Bind(wx.EVT_SIZE, self.OnSize)def OnPaint(self, event):bdc = wx.PaintDC(self)dc = wx.GCDC(bdc)font_face = self.GetFont()font_color = self.GetForegroundColour()dc.SetFont(font_face)dc.SetTextForeground(font_color)dc.DrawText(self.GetLabel(), 0, 0)def OnSize(self, event):self.Refresh()event.Skip()

最终效果如图:

 

注意如果你想打包的话,需要代码中中引入下面三个模块:

import six
import packaging
import packaging.version
import packaging.specifiers
import packaging.requirements

这篇关于教你用Python制作一个NBA球员数据查询小程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/422551

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的