很开心你能在万千博文中打开这一篇,希望能给你带来一定的帮助!
如果有什么问题,都可以添加下方我的联系方式,联系我噢~
⭐️⭐️⭐️⭐️⭐️沟通交流,一起成为技术达人!!!⭐️⭐️⭐️⭐️⭐️⭐️
⭐️⭐️⭐️⭐️⭐️加油ヾ(◍°∇°◍)ノ゙⭐️⭐️⭐️⭐️⭐️⭐️
因为粉丝福利,所以想自己写一个抽奖小程序,用于实现粉丝抽奖结果。
原本规划的比较理想:
- 实时拉取评论用户信息
- 数据清洗,数据去重
- 存储评论用户信息
- 前端酷炫的展示效果
哈哈,但是理想是丰满的,现实是骨感的,加上最近比较忙,就简单写了一下,实现了:
- 用户数据拉取
- 数据清洗,数据去重
- 中奖数据抽取
总体算后端实现了50%吧,前端0% ,哈哈~~~后面有时间了再进一步吧!
用Python 实现的,以下为相关代码。使用过程中,有点报错,最终使用postman,手动获取的,
哈哈哈~~~后面再优化吧
import json
import requests
def request_get(url, param):
fails = 0
while True:
try:
if fails >= 20:
break
ret = requests.get(url=url, params=param, timeout=10)
if ret.status_code == 200:
text = json.loads(ret.text)
else:
continue
except:
fails += 1
print('网络连接出现问题, 正在尝试再次请求: ', fails)
else:
break
return text
def request_post(url, param):
fails = 0
while True:
try:
if fails >= 20:
break
# headers = {'content-type': 'application/json'}
ret = requests.post(url, json=param, timeout=10)
if ret.status_code == 200:
text = json.loads(ret.text)
else:
continue
except:
fails += 1
print('网络连接出现问题, 正在尝试再次请求: ', fails)
else:
break
return text
数据接口不适合放出来,就不放啦~
用户数据不知道合不合适放出来,也就不放啦~
因为我原本想的是要做一个酷炫的前端,也有找到了一些不错的案例,3D抽奖的效果,需要用户头像,就在清洗数据的同时,也存储了用户头像的链接,以下是完整代码:
import json
def getData():
with open("data.json", 'r') as f:
temp = json.loads(f.read())
templist = temp['data']['list']
user = []
for i in templist:
temp={
'nickName':i['info']['nickName'],
'avatar':i['info']['avatar']
}
user.append(temp)
result = [dict(t) for t in set([tuple(d.items()) for d in user])]
print(result)
print(len(result))
return result
if __name__ == '__main__':
getData()
这一步是重复数据去重
result = [dict(t) for t in set([tuple(d.items()) for d in user])]
中奖名单抽取---完整代码
import random
from giftchoose.userData import getdata
def getgift():
num = getdata() # 用于存放抽奖用户信息
print("欢迎来到抽奖小程序!")
print("参与抽奖的用户如下:")
for i in num:
print(i)
usernum = len(num)
reward = 2
usernum = int(usernum)
reward = int(reward)
resultList = [] # 用于存放随机数结果
def generateRand(counter):
tempInt = random.randint(0, usernum-1) # 生成一个范围内的临时随机数
if(counter <= reward): # 先看随机数的总个数是不是够了,如果不够
if(tempInt not in resultList): # 再检查当前已经生成的临时随机数是不是已经存在
resultList.append(tempInt) # 如果不存在,则将其追加到结果resultList中
counter += 1 # 然后将表示有效结果的个数加1
generateRand(counter) # 不管上面的if是否成立,都要递归。
generateRand(1) # 调用递归函数,并给当前要生成的有效随机数的个序号置为1
prize = [] # 用于存放中奖号码
# 将中奖号码添加到结果prize中
for j in range(reward):
prize.append(num[resultList[j]])
print("\n中奖用户:") # 输出中奖结果
for k in range(reward):
print(prize[k], end="\n")
if __name__ == '__main__':
getgift()
第二期赠书活动,就用这个程序进行抽奖吧!一起看看是哪些幸运的小伙伴吧~ ⭐️⭐️⭐️⭐️
项目结构,太简单了,其实也算不上项目了
循环遍历
old_list = [10, 1, 1, 2, 3, 4, 5, 1, 2, 3, 6, 7, 8, 8, 9, 10, 10] def one(): new_list = [] for i in old_list: if i not in new_list: new_list.append(i) print(new_list)
使用dict:
使用list项作为键创建dict,会自动删除任何重复项,保留原顺序,因为dict不能有重复的键。
old_list = [10, 1, 1, 2, 3, 4, 5, 1, 2, 3, 6, 7, 8, 8, 9, 10, 10] def useDict(): new_list = list(dict.fromkeys(old_list)) print(new_list)
使用set:将list转化为set再转化为list,set有自动去重功能,缺点:新的list不保证原顺序。
def useSet(): new_list = list(set(old_list)) print(new_list)
使用set 并保证顺序:不能保证顺序,咱就给他加个原来的key,这样不就保障了嘛~
def keepOrder(): new_list = list(set(old_list)) new_list.sort(key=old_list.index) print(new_list)
推荐图书:从零开始读懂量子力学(精装加强版)
内容简介
量子力学是现代物理学的基石,推动了科学技术的快速发展。在今天,量子依然是新闻热点。
本书将为广大科技爱好者系统、严谨地介绍量子力学的基本原理和应用。读者需要熟悉高中物理和数学的相关内容,愿意学习科学的思维方式。虽然量子力学是一门有着神秘面纱、打破生活常识、颠覆人类认知的现代科学,但是读者只要愿意随着本书一起思考,就一定能够清楚地了解量子力学理论的基本概念,最终全面认识它在科学体系中的作用和对现代技术的贡献。
本书的叙述方式是一边讲解科学理论,一边介绍重要的实验现象和科学原理的应用。本书在第一篇中依次讲解了状态叠加、波粒二象性、不确定性原理等基本概念;在第二篇中介绍了量子力学在凝聚态物理和基本粒子物理领域中的应用。同时,对由量子力学催生的现代电子技术,也着重做了介绍。
作者简介
戴瑾,毕业于北京大学物理系。早年从事理论物理学研究。赴美国德克萨斯大学留学,加入了诺贝尔物理奖获得者温伯格的研究小组,师从基础物理突破奖获得者Joeseph Polchinski教授,获得博士学位。与Polchinski共同创造了超弦理论中的D-膜分支。后又在无线通信和半导体芯片领域工作二十余年。现任某半导体公司高管。
等不及的小伙伴也可以点击下方链接先睹为快:
《从零开始读懂量子力学(精装加强版)》
图书数量:本次送出 3 本 !!!⭐️⭐️⭐️
活动时间:截止到 2023-05-10 12:00:00抽奖方式:
- 2本,送给 高质量评论且该评论赞数的前两名!
- 1本,评论区随机挑选一位小伙伴送书一本!
参与方式:关注博主、点赞、收藏,评论区留言
获奖名单
中奖名单:请关注博主动态
名单公布时间:2023-05-10 下午
中奖用户:
1. 几分醉意.@几分醉意.⭐️⭐️⭐️
2.艾派森@艾派森⭐️⭐️
3.在下周周ovo@在下周周ovo⭐️⭐️
恭喜以上中奖的小伙伴,请及时联系博主!!
这次没中奖的小伙伴,也不要灰心啦,关注博主其他正在进行的赠书活动,总有一次,图书让你带回家