Python如何利用双色球每天薅个煎饼果子

Posted 小_源

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python如何利用双色球每天薅个煎饼果子相关的知识,希望对你有一定的参考价值。

本文同步发表于我的微信公众号,扫一扫文章底部的二维码或在微信搜索 极客导航 即可关注,每个工作日都有文章更新。

一、概况

我们手里有了2389条双色球数据,除了昨天分析了红球和篮球出现的次数。还能干什么呢?我们脑海中出现了一个清晰而又可笑的商业模式。有没有人想知道这次买的双色球历史上是否中过奖呢?, 我好奇的去网上搜了搜,果然找到了一个网站(http://china-ssq.com/)
截图如下:

看了大概网站的功能,就是提供历史中奖查询的。具体不知道这个网站开了大概多久,是否盈利。不管三七二十一,我也决定自己实现一个。

二、实现网站

  • 模型

我用的是Django框架来实现这个网站的,首先我根据数据库字段反向生成了模型类。

 python manage.py inspectdb > ssq/models.py

生成的模型类如下:

class SsqInfo(models.Model):
    red = models.CharField(max_length=45, blank=True, null=True)
    blue = models.CharField(max_length=45, blank=True, null=True)
    date = models.CharField(max_length=45, blank=True, null=True)

    class Meta:
        managed = False
        db_table = 'ssq_info'

  • 模板

我们得快速搞定一个页面,大概长个样子:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>查询双色球是否中奖</title>
    <style>
        * 
            margin: 0;
            padding: 0;
        

        header 
            font-weight: bold;
        

        ul 
            list-style: none outside none;
        

        #reddiv 
            width: 660px;
            float: left;
        

        #bluediv 
            width: 400px;
            float: left;
            margin: 0 0 0 60px;
        

        li 
            display: inline-block;
            margin: 8px 5px;
            padding: 5px;
            width: 30px;
            height: 30px;
            font: bold 18px/30px arial;
            border: 1px #ddd solid;
            color: #444;
            border-radius: 31px;
            text-align: center;
            background-image: -webkit-radial-gradient(circle at top, rgb(247, 247, 247), rgb(222, 222, 222));
            background-image: radial-gradient(circle at top, rgb(247, 247, 247), rgb(222, 222, 222));
        

        ul > li:hover 
            cursor: pointer;
            background-image: -webkit-radial-gradient(circle at top, rgb(247, 247, 247), rgb(255, 204, 204));
            background-image: radial-gradient(circle at top, rgb(247, 247, 247), rgb(255, 204, 204));
        

        #reddiv header 
            color: red;
        

        #bluediv header 
            color: blue;
        

        .redball 
            color: #fff;
            background-image: -webkit-radial-gradient(circle at top, rgb(255, 51, 51), rgb(255, 0, 0));
            background-image: radial-gradient(circle at top, rgb(255, 51, 51), rgb(255, 0, 0));
        

        .blueball 
            color: #fff;
            background-image: -webkit-radial-gradient(circle at top, rgb(0, 85, 204), rgb(0, 0, 225));
            background-image: radial-gradient(circle at top, rgb(0, 85, 204), rgb(0, 0, 225));
        




    </style>
</head>

<body>
<div id="reddiv">
    <header>红球区</header>
    <ul id="redul">
        <li>01</li>
        <li>02</li>
        <li>03</li>
        <li>04</li>
        <li>05</li>
        <li>06</li>
        <li>07</li>
        <li>08</li>
        <li>09</li>
        <li>10</li>
        <li>11</li>
        <li>12</li>
        <li>13</li>
        <li>14</li>
        <li>15</li>
        <li>16</li>
        <li>17</li>
        <li>18</li>
        <li>19</li>
        <li>20</li>
        <li>21</li>
        <li>22</li>
        <li>23</li>
        <li>24</li>
        <li>25</li>
        <li>26</li>
        <li>27</li>
        <li>28</li>
        <li>29</li>
        <li>30</li>
        <li>31</li>
        <li>32</li>
        <li>33</li>
    </ul>
</div>
<div id="bluediv">
    <header>蓝球区</header>
    <ul>
        <li>01</li>
        <li>02</li>
        <li>03</li>
        <li>04</li>
        <li>05</li>
        <li>06</li>
        <li>07</li>
        <li>08</li>
        <li>09</li>
        <li>10</li>
        <li>11</li>
        <li>12</li>
        <li>13</li>
        <li>14</li>
        <li>15</li>
        <li>16</li>
    </ul>
</div>

<div>
    <button type="submit" id="btn">查询</button>
</div>

<div style="width: 1000px" id="infodiv">

</div>


</body>
</html>

数据有了,模型类有了,剩下的就是我们最关键的业务逻辑了。

  • 业务

首先我们需要知道双色球的中奖规则,抓紧百度一下:


规则了解后,我们业务就清晰多了,大概就算出我们选择的双色球号码和历史开奖号码,有多少个红球是一样的。

from django.shortcuts import render, HttpResponse

from .models import SsqInfo
import json
from django.views.decorators.csrf import csrf_exempt


# Create your views here.
@csrf_exempt
def index(request):
    if request.method == 'GET':
        return render(request, 'index.html')

    else:
        # 前端参数
        reds = request.POST.getlist('red')
        blue = request.POST.get('blue')

        # ['11', '22', '33', '07', '06', '18']->[6, 7, 11, 18, 22, 33]
        reds = sorted([int(i) for i in reds])

        # [6, 7, 11, 18, 22, 33]->'06,07,11,18,22,33'
        red = ",".join([str(i).zfill(2) for i in reds])

        # 返回结果
        results = []

        # 先根据红球取出红球全部一样的
        red_ssqs = SsqInfo.objects.filter(red=red).all()

        for obj in red_ssqs:
            if obj.blue == blue:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "6红1蓝 一等奖"
                results.append(d)
            else:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "6红0蓝 二等奖"
                results.append(d)

        # 在取出全部双色球
        ssqs = SsqInfo.objects.all()

        for obj in ssqs:
            s1 = set(sorted(set(([int(i) for i in obj.red.split(",")]))))
            s2 = set(reds)

            # 历史s1=8,12,16,19,26,32
            # 前端s2 = [6, 7, 16, 18, 22, 33]
            # s1&s2的交集 16
            length = len(s1 & s2)  # 取交集长度

            # 三等奖
            if length == 5 and obj.blue == blue:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "5红1蓝 三等奖"
                results.append(d)

            # 四等奖
            if length == 5 and obj.blue != blue:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "中5红0蓝 四等奖"
                results.append(d)

            if length == 4 and obj.blue == blue:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "中4红1蓝 四等奖"
                results.append(d)

            # 五等奖
            if length == 4 and obj.blue != blue:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "中4红0蓝 五等奖"
                results.append(d)
            if length == 3 and obj.blue == blue:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "中3红1蓝 五等奖"
                results.append(d)

            # 六等奖
            if length == 2 and obj.blue == blue:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "中2红1蓝 六等奖"
                results.append(d)

            if length == 1 and obj.blue == blue:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "中2红1蓝 六等奖"
                results.append(d)

            if length == 0 and obj.blue == blue:
                d = "red": obj.red, "blue": obj.blue, "date": obj.date, 'desc': "中0红1蓝 六等奖"
                results.append(d)

        return HttpResponse(json.dumps("data": results, ensure_ascii=False), content_type='application/json')

业务写完,我们前端用ajax调用一下,把返回的数据填在前端页面就基本上完事了。

<script>
    var arrayRed = new Array();
    var arrayBlue = new Array();
    $('#reddiv ul>li').click(function () 
        $(this).toggleClass('redball');
        var val = $(this).html()
        if ($.inArray(val, arrayRed) == -1) 
            arrayRed.push(val)
         else 
            index = arrayRed.indexOf(val)
            arrayRed.splice(index, 1)
        
    )


    $('#bluediv ul>li').click(function () 
        $(this).toggleClass('blueball');

        var val = $(this).html()
        if ($.inArray(val, arrayBlue) == -1) 
            arrayBlue.push(val)
         else 
            index = arrayBlue.indexOf(val)
            arrayBlue.splice(index, 1)
        
    );


    $("#btn").click(function (event) 
        if (arrayRed.length != 6) 
            alert('请选择6个红球')
         else if (arrayBlue.length != 1) 
            alert('请选择1个蓝球')
         else 
            div = $('#infodiv')
            $.ajax(
                type: "POST",
                data: red: arrayRed, blue: arrayBlue,
                dataType: "json",
                traditional: true,
                success: function (data) 
                    div.empty()
                    $.each(data.data, function (index, d) 
                        div.append("<div>" + d.red + "-----" + d.blue + "-----" + d.date + "-----" + d.desc +
                            "</div>"
                        )
                    )

                

            )


        


    )

</script>

调通以后,我抓紧试了一下。看看效果咋样?


还是六等奖多呀!

三、商业模式

来,咱们先像大佬一样,吹一波商业模式。到底能不能用这个每天赚个煎饼果子钱?我觉得是能的,首先如果只想建个网站就有点Low B了。现在小程序这么发达,完全可以写一个小程序,然后把小程序的二维码沾到大街小巷的彩票站,至少有一些人会好奇,自己选的号在历史上是否中过奖、中了多少次、中了多少钱,就会拿出手机扫一下。

就这个程序,一个共享虚拟主机就能搞定,一年服务器费用几十块钱。我就不相信一年几十块钱撸不回来。当你服务器撑不住的时候,也就是你赚大钱的时候到了。

目前此程序功能还不太完善,你不能只盯着双色球,还有其他的彩种,也是可以搞定的。在服务器上搞一个定时爬取,每天更新数据。当然你可以提供更多特色功能,比如根据姓名、生日、老婆名字生成双色球、vip、svip、ssvip等各种服务,让你享受帝王般的待遇。其他的功能我就不一一跟你们捣鼓了,自己想吧!

四、总结

虽然我们这辈子可能不会中双色球一等奖,但是我们确实可以这些数据干点有意思的事情。

欢迎关注我的公众号,我们一起学习。

以上是关于Python如何利用双色球每天薅个煎饼果子的主要内容,如果未能解决你的问题,请参考以下文章

FYF的煎饼果子

信息时代的“煎饼人”

翻煎饼问题

86.多继承

86.多继承

煎饼排序——选择排序的运用