|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
这个代码很简单,但是求助以及寻找办法的过程是非常享受的。感谢论坛所有的大神对我的帮助,我也坚持学了两个月,还记得小甲鱼让我们统计距离十万行代码还有多远的目标,我看了一下我只写了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[k]
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[Name] += rate
except KeyError:
Name_dict[Name] = 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[kt] += prize
count -= 1
prize -= 1
print(result)
Name_dict.pop(kt)
|
|