用C#开发的双色球走势图(一)

      首先声明,个人纯粹无聊之作,不作商业用途。

      我相信每个人都拥有一个梦想那就是有朝一日能中500W,这个也一直是我的梦想,并默默每一期双色球或多或少要贡献自己一点点力量,本人并不属于那种铁杆的彩票迷,每次都是纯粹娱乐而已,因为深知这个中奖的概率太低了,每一次买也是随机而已,运气好的话还能中个五块钱,运气不好的话随机买五注,甚至一个号码也中不到,每次去购买双色球都会看到走势图,所以个人最近就花了一点时间在这个上面,进行了一番研究,现将研究成果写出来,供园友一起探讨,愿各位早日中500W。

       双色球开奖数据个人也是从某网站抓取的,不保存到数据库,根据这些原始数据去分析双色球的走势,如有基本走势图、红球三分区走势图、红球四分区走势图、红球七分区走势图、红球连号走势图、和值走势图、篮球综合走势图和历史同期等等组成。

        首先介绍双色球原始数据是如何获取的?这个对于各位来说都比较简单,就是获取HTML源码,根据HTML去提取相关信息。

获取网页上数据后,再提取HTML相关信息,提取代码如下:

 1 /// <summary>
 2         /// 循环解析Tr
 3         /// </summary>
 4         /// <param name="wnRepo"></param>
 5         /// <param name="content"><tbody></tbody>之间的内容</param>
 6         private void ResolveTr(string content)
 7         {
 8             listWinNo.Clear();
 9             //--
10             string trContent = string.Empty;
11             WinNo wn = null;
12             Regex regex = new Regex("<tr>");
13             //在<tbody></tbody>之间的内容搜索所有匹配<tr>的项
14             MatchCollection matches = regex.Matches(content);
15             foreach (Match item in matches)
16             {
17                 wn = new WinNo();
18                 //如果当前匹配项的下一个匹配项的值不为空
19                 if (!string.IsNullOrEmpty(item.NextMatch().Value))
20                 {
21                     trContent = content.Substring(item.Index, item.NextMatch().Index - item.Index);
22                 }
23                 //最后一个<tr>的匹配项
24                 else
25                 {
26                     trContent = content.Substring(item.Index, content.Length - item.Index);
27                 }
28                 ResolveTd(ref wn, trContent);
29                 //wnRepo.Insert(wn);
30                 listWinNo.Add(wn);
31             }
32         }
View Code

存放双色球红球和篮球的实体类:

 1     #region * 实体类
 2     public class WinNo
 3     {
 4         /// <summary>
 5         /// 期号
 6         /// </summary>
 7         public string QiHao { get; set; }
 8 
 9         /// <summary>
10         /// 第一个红球号码
11         /// </summary>
12         public int R1 { get; set; }
13         /// <summary>
14         /// 第二个红球号码
15         /// </summary>
16         public int R2 { get; set; }
17         /// <summary>
18         /// 第三个红球号码
19         /// </summary>
20         public int R3 { get; set; }
21         /// <summary>
22         /// 第四个红球号码
23         /// </summary>
24         public int R4 { get; set; }
25         /// <summary>
26         /// 第五个红球号码
27         /// </summary>
28         public int R5 { get; set; }
29         /// <summary>
30         /// 第六个红球号码
31         /// </summary>
32         public int R6 { get; set; }
33         /// <summary>
34         /// 篮球号码
35         /// </summary>
36         public int B { get; set; }
37 
38         /// <summary>
39         /// 用于存放历史数据
40         /// </summary>
41         public List<string> Data { get; set; }
42     }
43     #endregion
View Code

获取每一期的号码,并返回一个实体:

 1  /// <summary>
 2         /// 在一个TR中,解析TD,获取一期的号码
 3         /// </summary>
 4         /// <param name="wn"></param>
 5         /// <param name="trContent"></param>
 6         private void ResolveTd(ref WinNo wn, string trContent)
 7         {
 8             List<int> redBoxList = null;
 9             //匹配期号的表达式
10             string patternQiHao = "<td align=\"center\" title=\"开奖日期";
11             Regex regex = new Regex(patternQiHao);
12             Match qhMatch = regex.Match(trContent);
13             wn.QiHao = trContent.Substring(qhMatch.Index + 17 + patternQiHao.Length, 7);
14             //匹配蓝球的表达式
15             string patternChartBall02 = "<td class=\"chartBall02\">";
16             regex = new Regex(patternChartBall02);
17             Match bMatch = regex.Match(trContent);
18             wn.B = Convert.ToInt32(trContent.Substring(bMatch.Index + patternChartBall02.Length, 2));
19             //存放匹配出来的红球号码
20             redBoxList = new List<int>();
21             //匹配红球的表达式
22             string patternChartBall01 = "<td class=\"chartBall01\">";
23             regex = new Regex(patternChartBall01);
24             MatchCollection rMatches = regex.Matches(trContent);
25             foreach (Match r in rMatches)
26             {
27                 redBoxList.Add(Convert.ToInt32(trContent.Substring(r.Index + patternChartBall01.Length, 2)));
28             }
29             //匹配红球的表达式
30             string patternChartBall07 = "<td class=\"chartBall07\">";
31             regex = new Regex(patternChartBall07);
32             rMatches = regex.Matches(trContent);
33             foreach (Match r in rMatches)
34             {
35                 redBoxList.Add(Convert.ToInt32(trContent.Substring(r.Index + patternChartBall07.Length, 2)));
36             }
37             //排序红球号码
38             redBoxList.Sort();
39             //第一个红球号码
40             wn.R1 = redBoxList[0];
41             //第二个红球号码
42             wn.R2 = redBoxList[1];
43             wn.R3 = redBoxList[2];
44             wn.R4 = redBoxList[3];
45             wn.R5 = redBoxList[4];
46             wn.R6 = redBoxList[5];
47         }
View Code

通过线程池同时去分析双色球的这些数据,节省显示数据的时间,让用户体验更好,这个每个人应该都会。

1.基本走势图

基本走势图包括红球和篮球的走势情况,包括可以显示和不显示遗漏数据的走势图,效果图分别如下:

不带遗漏数据的走势图:

显示双色球基本走势图关键代码如下:

 1   #region * 基本走势图
 2         /// <summary>
 3         /// 基本走势图
 4         /// </summary>
 5         /// <param name="obj"></param>
 6         private void GetData1(object obj)
 7         {
 8             table.Clear();
 9             cleantable.Clear();
10             if (listWinNo != null && listWinNo.Count > 0)
11             {
12                 foreach (WinNo item in listWinNo)
13                 {
14                     DataRow dr = table.NewRow();
15                     dr["QiHao"] = item.QiHao;
16                     dr["R" + item.R1] = "R" + GetStr(item.R1.ToString());//红1
17                     dr["R" + item.R2] = "R" + GetStr(item.R2.ToString());//红2
18                     dr["R" + item.R3] = "R" + GetStr(item.R3.ToString());//红3
19                     dr["R" + item.R4] = "R" + GetStr(item.R4.ToString());//红4
20                     dr["R" + item.R5] = "R" + GetStr(item.R5.ToString());//红5
21                     dr["R" + item.R6] = "R" + GetStr(item.R6.ToString());//红6
22                     dr["B" + item.B] = "B" + GetStr(item.B.ToString());//篮球
23                     table.Rows.Add(dr);
24 
25                     DataRow cleandr = cleantable.NewRow();
26                     cleandr["QiHao"] = item.QiHao;
27                     cleandr["R" + item.R1] = GetStr(item.R1.ToString());//红1
28                     cleandr["R" + item.R2] = GetStr(item.R2.ToString());//红2
29                     cleandr["R" + item.R3] = GetStr(item.R3.ToString());//红3
30                     cleandr["R" + item.R4] = GetStr(item.R4.ToString());//红4
31                     cleandr["R" + item.R5] = GetStr(item.R5.ToString());//红5
32                     cleandr["R" + item.R6] = GetStr(item.R6.ToString());//红6
33                     cleandr["B" + item.B] = GetStr(item.B.ToString());//篮球
34                     cleantable.Rows.Add(cleandr);
35                 }
36 
37                 for (int j = 1; j < 34; j++)
38                 {
39                     int xint = 0;
40                     for (int i = 0; i < table.Rows.Count; i++)
41                     {
42                         if (string.IsNullOrEmpty(table.Rows[i]["R" + j].ToString()))
43                         {
44                             xint++;
45                             table.Rows[i]["R" + j] = xint;
46                         }
47                         else
48                         {
49                             xint = 0;
50                         }
51                     }
52                 }
53 
54                 for (int j = 1; j < 17; j++)
55                 {
56                     int xint = 0;
57                     for (int i = 0; i < table.Rows.Count; i++)
58                     {
59                         if (string.IsNullOrEmpty(table.Rows[i]["B" + j].ToString()))
60                         {
61                             xint++;
62                             table.Rows[i]["B" + j] = xint;
63                         }
64                         else
65                         {
66                             xint = 0;
67                         }
68                     }
69                 }
70 
71                 if (this.IsHandleCreated)
72                 {
73                     this.Invoke((MethodInvoker)delegate
74                     {
75                         if (flag)
76                         {
77                             cleantable.DefaultView.Sort = "QiHao DESC";
78                             this.gridControl1.DataSource = cleantable.DefaultView.ToTable();
79                         }
80                         else
81                         {
82                             table.DefaultView.Sort = "QiHao DESC";
83                             this.gridControl1.DataSource = table.DefaultView.ToTable();
84                         }
85                     });
86                 }
87             }
88         }
89         #endregion
View Code

红球三分区走势图显示效果如下:(同时也包括带遗漏数据和不带遗漏数据的效果)

不带遗漏数据的红球三分区走势图效果:

实现红球三分区走势图关键代码:

  1   #region * 红球三分区走势图
  2         /// <summary>
  3         /// 红球三分区走势图
  4         /// </summary>
  5         /// <param name="obj"></param>
  6         private void GetData2(object obj)
  7         {
  8             sedredtable.Clear();
  9             sedcleanredtable.Clear();
 10             if (listWinNo != null && listWinNo.Count > 0)
 11             {
 12                 foreach (WinNo item in listWinNo)
 13                 {
 14                     List<int> redList = new List<int>();
 15                     redList.Add(item.R1);
 16                     redList.Add(item.R2);
 17                     redList.Add(item.R3);
 18                     redList.Add(item.R4);
 19                     redList.Add(item.R5);
 20                     redList.Add(item.R6);
 21                     //--
 22                     DataRow reddr = sedredtable.NewRow();
 23                     reddr["QiHao"] = item.QiHao;
 24                     reddr["R" + item.R1] = "R" + GetStr(item.R1.ToString());//红1
 25                     reddr["R" + item.R2] = "R" + GetStr(item.R2.ToString());//红2
 26                     reddr["R" + item.R3] = "R" + GetStr(item.R3.ToString());//红3
 27                     reddr["R" + item.R4] = "R" + GetStr(item.R4.ToString());//红4
 28                     reddr["R" + item.R5] = "R" + GetStr(item.R5.ToString());//红5
 29                     reddr["R" + item.R6] = "R" + GetStr(item.R6.ToString());//红6
 30                     reddr["A1"] = item.R1 + item.R2 + item.R3 + item.R4 + item.R5 + item.R6;//和值
 31                     reddr["A2"] = item.R6 - item.R1;//跨度
 32                     reddr["A3"] = GetQujian(redList);//区间比
 33                     reddr["A4"] = GetJio(redList);//奇偶比
 34                     sedredtable.Rows.Add(reddr);
 35 
 36                     DataRow cleanreddr = sedcleanredtable.NewRow();
 37                     cleanreddr["QiHao"] = item.QiHao;
 38                     cleanreddr["R" + item.R1] = GetStr(item.R1.ToString());//红1
 39                     cleanreddr["R" + item.R2] = GetStr(item.R2.ToString());//红2
 40                     cleanreddr["R" + item.R3] = GetStr(item.R3.ToString());//红3
 41                     cleanreddr["R" + item.R4] = GetStr(item.R4.ToString());//红4
 42                     cleanreddr["R" + item.R5] = GetStr(item.R5.ToString());//红5
 43                     cleanreddr["R" + item.R6] = GetStr(item.R6.ToString());//红6
 44                     cleanreddr["A1"] = item.R1 + item.R2 + item.R3 + item.R4 + item.R5 + item.R6;//和值
 45                     cleanreddr["A2"] = item.R6 - item.R1;//跨度
 46                     cleanreddr["A3"] = GetQujian(redList);//区间比
 47                     cleanreddr["A4"] = GetJio(redList);//奇偶比
 48                     sedcleanredtable.Rows.Add(cleanreddr);
 49                 }
 50 
 51                 for (int j = 1; j < 34; j++)
 52                 {
 53                     int xint = 0;
 54                     for (int i = 0; i < sedredtable.Rows.Count; i++)
 55                     {
 56                         if (string.IsNullOrEmpty(sedredtable.Rows[i]["R" + j].ToString()))
 57                         {
 58                             xint++;
 59                             sedredtable.Rows[i]["R" + j] = xint;
 60                         }
 61                         else
 62                         {
 63                             xint = 0;
 64                         }
 65                     }
 66                 }
 67 
 68                 if (this.IsHandleCreated)
 69                 {
 70                     this.Invoke((MethodInvoker)delegate
 71                     {
 72                         if (flag)
 73                         {
 74                             sedcleanredtable.DefaultView.Sort = "QiHao DESC";
 75                             this.gridControl2.DataSource = sedcleanredtable.DefaultView.ToTable();
 76                         }
 77                         else
 78                         {
 79                             sedredtable.DefaultView.Sort = "QiHao DESC";
 80                             this.gridControl2.DataSource = sedredtable.DefaultView.ToTable();
 81                         }
 82                     });
 83                 }
 84             }
 85         }
 86 
 87         /// <summary>
 88         /// 区间比
 89         /// </summary>
 90         /// <param name="redList"></param>
 91         /// <returns></returns>
 92         private string GetQujian(List<int> redList)
 93         {
 94             int xint1 = 0;
 95             int xint2 = 0;
 96             int xint3 = 0;
 97             foreach (int item in redList)
 98             {
 99                 if (item < 12)
100                 {
101                     xint1++;
102                 }
103                 else if (item > 11 && item < 23)
104                 {
105                     xint2++;
106                 }
107                 else if (item > 22)
108                 {
109                     xint3++;
110                 }
111             }
112             return xint1.ToString() + ":" + xint2.ToString() + ":" + xint3.ToString();
113         }
114 
115         /// <summary>
116         /// 奇偶比
117         /// </summary>
118         /// <param name="redList"></param>
119         /// <returns></returns>
120         private string GetJio(List<int> redList)
121         {
122             int xint1 = 0;//奇数
123             int xint2 = 0;//偶数
124             foreach (int item in redList)
125             {
126                 if (item % 2 == 0)
127                 {
128                     xint2++;//偶数
129                 }
130                 else
131                 {
132                     xint1++;//奇数
133                 }
134             }
135             return xint1.ToString() + ":" + xint2.ToString();
136         }
137         #endregion
View Code

 

请看下篇:  http://www.cnblogs.com/jara/p/4122379.html

posted @ 2014-11-26 08:23  Jara  阅读(2444)  评论(0编辑  收藏  举报