首先声明,个人纯粹无聊之作,不作商业用途。
我相信每个人都拥有一个梦想那就是有朝一日能中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 }
存放双色球红球和篮球的实体类:
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
获取每一期的号码,并返回一个实体:
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 }
通过线程池同时去分析双色球的这些数据,节省显示数据的时间,让用户体验更好,这个每个人应该都会。
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
红球三分区走势图显示效果如下:(同时也包括带遗漏数据和不带遗漏数据的效果)
不带遗漏数据的红球三分区走势图效果:
实现红球三分区走势图关键代码:
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