课后作业要求自己动手于是我自己做了一个抽奖程序
这个代码很简单,但是求助以及寻找办法的过程是非常享受的。感谢论坛所有的大神对我的帮助,我也坚持学了两个月,还记得小甲鱼让我们统计距离十万行代码还有多远的目标,我看了一下我只写了234行,哈哈哈,任重而道远。下面附上我的源代码,以及一些自己标注的解释
一定要注意要自己写用文档统计出姓名已经所占权重!!!
#一共三等奖设计,而且还要一下循环抽完,抽到的原来的人要剔除
import random as r
import easygui as g
g.msgbox(msg='欢迎使用W1ND抽奖程序',title='随机抽奖')
def test():
global Name_dict
s_sum = sum(Name_dict.values())
h = r.randint(0,s_sum)
c_sum = 0
for k in Name_dict.keys():
c_sum += Name_dict
if c_sum > h :
return k
#存储名字和所占的比重,昨晚想到了解决办法,就是在文档里输入【名字+ : +权重】,然后在读取
start_dir = g.fileopenbox(msg='请选择你已经整理好的抽奖名单',title='抽奖文件选择')
with open(start_dir,encoding='utf-8') as f:
Name_dict = {}
for i in f:
(a,b) = i.split(':',1) #这里字符串split分隔之后可以用这种形式返回的,知识点遗忘
c_num = int(b)
Name = a
rate = c_num
try: #用字典的形式进行权重统计
Name_dict += rate
except KeyError:
Name_dict = rate
g.msgbox(msg='权重统计完成')
g.msgbox(msg='参加抽奖的人数有: %d 个' % len(Name_dict))
#至此全部统计完成,并且以字典的形式储存在Name_dict中
#这里是关键,就是进行抽奖的地方。
prize =3
count =3
while count:
result = dict([(x,0) for x in Name_dict.keys()])# 这一步简直太厉害了!!!
kt = test()
result += prize
count -= 1
prize -= 1
print(result)
Name_dict.pop(kt)
页:
[1]