鱼C论坛

 找回密码
 立即注册
查看: 2308|回复: 0

[原创] 课后作业要求自己动手于是我自己做了一个抽奖程序

[复制链接]
发表于 2021-11-1 21:22:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-16 10:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表