Python通过最近100期的大乐透数据统计各个数字的概率

前言

前几天商场随机买了几注大乐透彩票花了20元(机选5注,自己手动选了5注),今天发现中了5块钱,好亏啊,想写一个程序程序帮我计算辅助一下哪些数字概率大一些

思路

获取最近100期的号码,统计一下每个数字在100期内的概率,看看是不是在100期内是不是真随机,各数字的概率差距有多大,看下哪些数字的出现次数多

提示:每期中一等奖的都是1/21425712的机会。中大奖概率会很小,每一期都会重置概率。

获取数据

大乐透官网:www.lottery.gov.cn/

img.png 选择最近一百期,打开F12,找到任意一期其中一个数字的xpath:/html/body/div[4]/div[2]/div/div/div[1]/table/tbody/tr[1]/td[6]

img_2.png 然后分析一下xpath,使用Chrome 插件:xpath-helper

img_1.png 尝试调整一下xpath ,让插件获取到最近100期的数据:
xpath:/html/body/div[4]/div[2]/div/div/div[1]/table/tbody/tr

img_3.png 把图中RESULTS (100)的内容复制出来进行处理分析处理

处理

原数据内容为:

230330406101125070904061011250709
230340709101524041207091015240412
230350714232529021107142325290211
230360113222631021001132226310210
....

分别是 期号+中奖号码+中奖号码(有重复的中奖号码) 思路:

  • 1.以换行分割得到每一期的内容
  • 2.去掉每一期内容的期数,和重复的中奖号码
  • 3.每隔两个数字分割,得出中奖的每一个数组
  • 4.对数字进行统计次数(前区和后区独立开,因为会重复)

编码


import matplotlib.pyplot as plt  
from collections import Counter
from pylab import mpl


begin_all_list = []
end_all_list = []

# 读取文件
with open('./100.txt','r') as f:
    res = f.read()

    for i in res.split('\n'):
        one_data = i[5:-14]
        # print(i,one_data)
        begin,end = one_data[:10],one_data[10:] # 得到前区后区的字符串
        bengin_list = [begin[i:i+2] for i in range(0, len(begin), 2)] # 前区切割成数组
        end_list = [end[i:i+2] for i in range(0, len(end), 2)] # 后区切割成数组
        print(i,one_data,begin,end,bengin_list,end_list)
        begin_all_list += bengin_list # 搜集所有的前区号码
        end_all_list +=end_list # 收集所有后区号码

begin_ball = range(1,36) 
end_ball = range(1,13)

begin_ata_dict = {}
for i in begin_ball: # 遍历计算所有号码在前区号码的出现的次数
    counter = begin_all_list.count('%02d' % i)
    rate = round(counter/(5*100),0)
    begin_ata_dict[str(i)] = {
        "word":counter,
        "count":counter
        }


end_data_dict = {}
for i in end_ball: # 遍历计算所有号码在后区号码的出现的次数
    counter = end_all_list.count('%02d' % i)
    rate = round(counter/(2*100),2)
    end_data_dict[str(i)] = {
        "word":counter,
        "count":counter
        }
print(begin_ata_dict,end_data_dict)

mpl.rcParams["font.sans-serif"] = ["SimHei"]

# 设置正常显示符号
mpl.rcParams["axes.unicode_minus"] = False

count_list = [x['count'] for x in list(begin_ata_dict.values())]
plt.title("前区")
plt.grid(ls="--", alpha=0.5)
print(list(begin_ata_dict.values()), list(begin_ata_dict.values()))
plt.bar(list(begin_ata_dict.keys()), count_list) # 画图指定X,Y轴内容
for i in range(len(count_list)):
    word = list(begin_ata_dict.values())[i]['word']
    print('wrod',word,list(begin_ata_dict.keys())[i])
    plt.text(list(begin_ata_dict.keys())[i], word, word, va="bottom", ha="center") # 柱状图顶部文字

plt.show()

# 暂不能同时显示两张图片,取消注释后单独运行展示

# count_list = [x['count'] for x in list(end_data_dict.values())]
# plt.title("后区")
# plt.grid(ls="--", alpha=0.5)
# print(list(end_data_dict.values()), list(end_data_dict.values()))
# plt.bar(list(end_data_dict.keys()), count_list)
# for i in range(len(count_list)):
#     word = list(end_data_dict.values())[i]['word']
#     print('wrod',word,list(end_data_dict.keys())[i])
#     plt.text(list(end_data_dict.keys())[i], word, word, va="bottom", ha="center")

# plt.show()

统计前区后区的效果:

img_4.png

img_5.png

结论&简单分析

看起来毫无规律,前区出现次数最大差距 22-8=16次,所以我觉得按理来说买热门的数字应该概率大一些。

所以简单分析(复杂的我也不会==!):

前区次数的众数是13次,出现13次的号码是09,12,21,29,31,34,35这几位数
后区次数的众数是14次,出现14次的号码是03,06这几位数
简单分析这几个数字是100期以内出现次数最多的数字,继续接着买出现次数多的数字概率应该大一点吧

大家有什么更好分析的方法呢?

如果你对Python感兴趣,想要学习python,这里给大家分享一份Python全套学习资料,都是我自己学习时整理的,希望可以帮到你,一起加油!

😝有需要的小伙伴,可以V扫描下方二维码免费领取🆓

1️⃣零基础入门

① 学习路线

对于从来没有接触过Python的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

② 路线对应学习视频

还有很多适合0基础入门的学习视频,有了这些视频,轻轻松松上手Python~
在这里插入图片描述

③练习题

每节视频课后,都有对应的练习题哦,可以检验学习成果哈哈!
在这里插入图片描述

2️⃣国内外Python书籍、文档

① 文档和书籍资料

在这里插入图片描述

3️⃣Python工具包+项目源码合集

①Python工具包

学习Python常用的开发软件都在这里了!每个都有详细的安装教程,保证你可以安装成功哦!
在这里插入图片描述

②Python实战案例

光学理论是没用的,要学会跟着一起敲代码,动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。100+实战案例源码等你来拿!
在这里插入图片描述

③Python小游戏源码

如果觉得上面的实战案例有点枯燥,可以试试自己用Python编写小游戏,让你的学习过程中增添一点趣味!
在这里插入图片描述

4️⃣Python面试题

我们学会了Python之后,有了技能就可以出去找工作啦!下面这些面试题是都来自阿里、腾讯、字节等一线互联网大厂,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
在这里插入图片描述
在这里插入图片描述

上述所有资料 ⚡️ ,朋友们如果有需要的,可以扫描下方👇👇👇二维码免费领取🆓

  • 22
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
我们可以通过以下步骤使用 Python 爬取大乐透某一到某一的开奖结果数据: 1. 分析网页结构,找到包含开奖结果数据的网页 URL。 2. 使用 Python 的 requests 库向该网页发送请求,获取网页源代码。 3. 使用 Python 的 Beautiful Soup 库解析网页源代码,提取开奖结果数据。 4. 将数据保存到本地或数据库中。 下面是一个示例代码,爬取第 20001 到第 20010 大乐透开奖结果数据: ```python import requests from bs4 import BeautifulSoup headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3'} url_template = 'http://datachart.500.com/dlt/history/newinc/history.php?start={}&end={}' start_issue = 20001 end_issue = 20010 result = [] # 保存结果数据的列表 for i in range(start_issue, end_issue + 1): url = url_template.format(i, i) res = requests.get(url, headers=headers) soup = BeautifulSoup(res.text, 'html.parser') trs = soup.select('table tbody tr') tds = trs[-1].select('td') reds = [td.text for td in tds[:5]] blues = [td.text for td in tds[5:]] result.append({'issue': i, 'reds': reds, 'blues': blues}) print(result) # 打印结果数据 ``` 该代码通过循环遍历需要爬取的数,依次访问每一的网页,解析网页源代码,提取结果数据,并将结果数据保存到一个列表中。最终,我们可以将结果数据打印出来,或者保存到本地文件或数据库中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值