公司年会,需要一个非常简单的抽奖工具,因为我的电脑是windows
系统,年会要在同事的Mac
上面使用,考虑到开发的便捷性和跨平台特性,用Python
是最好的选择。
1、获取抽奖名单。我拿到的人员名单在一个excel
表格中,使用openpyxl
或者xlrd
库可以很容易读到所有的人名,放入一个集合set
或者列表list
即可。
2、抽奖逻辑:每次点击开始抽奖时,都会把抽奖名单打乱。使用定时器,每隔一段时间,例如
50ms
,依据打乱的名单列表,按照索引不断修改文本框中的人名,点击停止时停止定时器,文本框中的人名就不会再变化,这时显示的人名即为中奖者。然后,将已经中奖的人名从列表中删掉,确保下次抽奖时不会重复中奖。显示界面: 抽奖效果
3、主要代码如下。显示的界面可以用
qtDesigner
画出来,再用pyuic
自动生成界面代码。代码在windows
系统和苹果Mac
上面都可以直接运行,只是字体显示稍有不同。
#!/usr/bin/env python3
from xlrd import open_workbook
from lottery_draw import Ui_MainForm
import sys
import random
import time
import os.path
from PyQt5.QtCore import QThread, QTimer
from PyQt5 import QtCore, QtGui, QtWidgets
NAME_SET = set()
def get_all_names():
p_path = os.path.split(os.path.realpath(__file__))[0]
table = open_workbook(p_path + '/抽奖名单.xlsx').sheet_by_index(1)
for cell in table.col_values(0):
if not cell:
break
NAME_SET.add(cell.strip())
class Py_Select(Ui_MainForm, QtWidgets.QWidget):
def __init__(self):
super(Py_Select, self).__init__()
self.setupUi(self)
self.init()
self.setWindowTitle("抽奖工具")
def init(self):
get_all_names()
self.name_list = list(NAME_SET)
self.boxNames.setText('')
self.btnStart.clicked.connect(self._start)
self.btnStop.clicked.connect(self._stop)
self.index = 0
self.timer = None
def _start(self):
self.btnStart.setHidden(True)
self.btnStop.setHidden(False)
self.name_list = list(NAME_SET)
random.seed(int(time.time()))
random.shuffle(self.name_list)
if not self.timer:
self.timer = QTimer()
self.timer.timeout.connect(self._range_name)
self.timer.start(50)
def _range_name(self):
self.index += 1
if self.index >= len(self.name_list):
self.index = 0
self.boxNames.setText(self.name_list[self.index])
def _stop(self):
if self.timer:
self.timer.stop()
NAME_SET.discard(self.boxNames.text().strip())
self.btnStart.setHidden(False)
if __name__ == '__main__':
app = QtWidgets.QApplication(sys.argv)
myshow = Py_Select()
myshow.show()
sys.exit(app.exec_())
网友评论