爆竹声中一岁除,春风送暖入屠苏;千门万户曈曈日,总把新桃换旧符。
–宋/王安石《元日》
年末马上就要到了,一般这个时候,每家公司基本都开始准备年终聚餐以及年终总结了,当然必不可少的肯定是大家都想得到的抽奖环节了
比如特等奖:华为mate30
一等奖:电动自行车
。。。
幸运奖:50元现金
相信上面这些奖品,大家都想得到。公司抽奖有多种多样,比如每人一个标签纸,统一放到纸箱上抽奖,今天给大家分享个抽奖小工具,使用Excel来实现,不过这个需要用到VBA的一些知识,大家可以直接使用。
首先看下成品效果,操作步骤先点击【立即抽奖】,当需要停止的时候,点击【停止抽奖】,最后选中需显示人员名称单元格,再点保存即可。
下面就给大家讲下,这是如何实现的。
操作步骤:
1、首先我们需要准备好人员清单,人员清单包含【工号】及【人员名单】信息,统一放置在[人员名单]工作表内,因工号是唯一的,这样同时实现可避免抽奖出现相同名字的人员
2、制作抽奖界面样板,首先我们先设置各奖项人员显示位置,在B2:B8位置分别输入各奖项的名称,并添加相应的背景色等内容
再添加抽奖使用的背景样式
3、我们在A1单元格输入如下公式:
=RANDBETWEEN(2,COUNTA(人员名单!A:A))
RANDBETWEEN函数,随机生成区间2~COUNTA(人员名单!A:A)之间的随机数
因我们【人员名单】第一行是标题,故需要从2开始,返回的是随机的行数
再在A2单元格输入公式:
=INDEX(人员名单!A:B,抽奖系统!A1,1)&CHAR(10)&INDEX(人员名单!A:B,抽奖系统!A1,2
公式运行后及得到工号及人员名称,Char(10)为换行符,起到自动换行作用
4、制作抽奖显示窗口,点击插入【文本】-【横向文本框】,输入文字,设置字体颜色为红色,字号选择28,加粗,去除文本框的框线及背景色
再点击显示窗口,输入公式:=A2
即把A2单元格的内容显示到文本框中,这是只要我们按F9,可以看到姓名随着变更了
5、插入抽奖及保存抽奖信息的窗口,点击【插入】,选择矩形,设置边框为白色,无填充,输入文字:开始抽奖,字号24,字体:华文彩云
分别插入3个矩形,命名为:立即抽奖;停止抽奖;保存抽奖
6、编写VBA代码,右击工作表名称-【查看代码】,输入如下三段代码
PrivateDeclarePtrSafe SubSleepLib"kernel32"(ByVal dwMillisecondsAsLong)'暂停 64位系统
'PrivateDeclareSubSleepLib"kernel32"(ByVal dwMillisecondsAsLong)'暂停 32位系统
Dim mark As Boolean
Sub 立即开始()
[A2] = "=INDEX(人员名单!A:B,抽奖系统!A1,1)&CHAR(10)&INDEX(人员名单!A:B,抽奖系统!A1,2)"
mark = True
Do While mark
DoEvents
Sleep 50
ActiveSheet.Calculate
Loop
End Sub
Sub 停止抽奖()
mark = False
End Sub
Sub 保存抽奖()
CH = [A1]
ActiveCell = [A2]
Sheets("人员名单").Cells(CH, 1).EntireRow.Delete
Application.EnableEvents = False
[A2] = ""
Application.EnableEvents = True
End Sub
7、再分别右击插入的矩形框,点击【指定宏】,分别指定以上设置的宏命令
这样一个抽奖小程序就做好,我们只要点击【立即抽奖】,再点击【停止抽奖】按钮,最终保存抽奖人名,即可。
此方法主要是应用了INDEX及RANDBETWEEN函数,再结合VBA程序制作而成。
数据原始档案,可从以下网盘下载:
链接: https://pan.baidu.com/s/19BsAE8M1IRk9MOxUG78FHQ
提取码: hq3q
如果觉得文章对你有帮助的话,希望大家帮忙点赞加分享哦~,谢谢
本文由彩虹Excel原创,欢迎关注,带你一起长知识!