当前位置:   article > 正文

PyQt5设计一个简单的抽奖系统_python 使用pyqt写一个抽奖程序

python 使用pyqt写一个抽奖程序

PyQt5抽奖系统

程序运行截图

抽奖系统界面截图

抽奖系统代码

该系统使用PyQt5模块以及openpyxl模块开发,需要使用pip安装导入PyQt5模块和openpyxl模块

import random, sys
from PyQt5.QtWidgets import QWidget, QFormLayout, QLineEdit, QVBoxLayout, QApplication, QPushButton, QDesktopWidget
from PyQt5.QtCore import pyqtSignal, QTimer
from openpyxl import load_workbook

NAME = [] #获奖用户名
TEL = [] #获奖用户电话
EXCEL_PATH = "./抽奖名单.xlsx"

'''抽奖窗口程序'''
class Lucky(QWidget):
    def __init__(self, parent=None):
        super(Lucky, self).__init__(parent=parent)
        self.status = False
        self.numTimer = QTimer()  # 创建一个定时器
        self.numTimer.timeout.connect(self.num_timer_out)  # 定时器超时触发函数
        self.nameLine = QLineEdit()
        self.telLine = QLineEdit()
        self.luckyBtn = QPushButton('开始抽奖')
        self.luckyBtn.clicked.connect(self.startTimer)  # 抽奖按钮连接槽函数
        self.formLayout = QFormLayout()
        self.formLayout.addRow('获奖名字', self.nameLine)
        self.formLayout.addRow('电话号码', self.telLine)
        self.vbox = QVBoxLayout()
        self.vbox.addLayout(self.formLayout)
        self.vbox.addWidget(self.luckyBtn)
        self.setLayout(self.vbox)
        self.show()
    def startTimer(self): #定时器函数
        self.status = ~self.status  # 取反
        if self.status:
            self.numTimer.start(1) #开启定时器并设置超时时间为1毫秒
            self.luckyBtn.setText('停止抽奖')  # 停止计时器
        else:
            self.numTimer.stop()
            self.luckyBtn.setText('开始抽奖')  # 开启计时器
    def num_timer_out(self): #定时器超时处理事件函数
        self.num = random.randint(1,2) #抽奖核心代码,从1到2中随机生成一个数字num
        self.nameLine.setText(NAME[self.num]) #抽取姓名列中的第num行
        self.telLine.setText(str(TEL[self.num])) #抽取电话列中的第num行
def read_excel(path): #抽奖名单获取函数
    luckyData = load_workbook(path) #读取Excel表格
    luckyTable = luckyData[luckyData.sheetnames[0]] #获取第一个工作表
    for luckyRow in luckyTable.iter_rows(min_row=1): #从第一行开始遍历所有行
        NAME.append(luckyRow[1].value) # 获取第1列的值
        TEL.append(luckyRow[2].value) # 获取第2列的值
def center(window): #窗口居中函数
    screenSize = QDesktopWidget().screenGeometry() #获取显示屏幕大小
    windowSize = window.geometry() #获取当前窗口大小
    newLeft = int((screenSize.width() - windowSize.width()) / 2)
    newTop = int((screenSize.height() - windowSize.height()) / 2)
    window.move(newLeft, newTop)

if __name__ == "__main__":
    read_excel(EXCEL_PATH)
    app = QApplication(sys.argv)
    draw = Lucky()
    draw.setWindowTitle("XX抽奖系统") #抽奖系统窗口名称
    draw.resize(400, 400)
    center(draw)
    sys.exit(app.exec_())
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61

抽奖数据格式

创建一个Excel表格,按照以下格式填入抽奖人信息,并将该表格放到和代码同一目录下

序号姓名电话
1张三15011111111
2李四15022222222
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/450591
推荐阅读
相关标签
  

闽ICP备14008679号