python数据分析1:获取双色球历史信息
来源:互联网 发布:pubmed数据库手机版 编辑:程序博客网 时间:2024/05/25 01:36
每个人都有一颗中双色球大奖的心,对于技术人员来说,通过技术分析,可以增加中奖几率,现使用python语言收集历史双色球中奖信息,之后进行预测分析。
说明:采用2016年5月15日获取的双色球数据为基础进行分析,总抽奖数1940次。
初级代码,有些内容比较繁琐,有更好的代码,大家可以分享。
#!/usr/bin/python# -*- coding:UTF-8 -*-#coding:utf-8#author:levycui#date:20160513#Description:双色球信息收集import urllib2from bs4 import BeautifulSoup#采用BeautifulSoupimport osimport re#伪装成浏览器登陆,获取网页源代码def getPage(href): headers = { 'User-Agent':'Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.1.6) Gecko/20091201 Firefox/3.5.6' } req = urllib2.Request( url = href , headers = headers ) try: post = urllib2.urlopen(req) except urllib2.HTTPError,e: print e.code print e.reason return post.read()#初始化url 双色球首页url = 'http://kaijiang.zhcw.com/zhcw/html/ssq/list_1.html' #===============================================================================#获取url总页数def getPageNum(url): num =0 page = getPage(url) soup = BeautifulSoup(page) strong = soup.find('td',colspan='7') # print strong if strong: result = strong.get_text().split(' ') # print result list_num = re.findall("[0-9]{1}",result[1]) # print list_num for i in range(len(list_num)): num = num*10 + int(list_num[i]) return num else: return 0#===============================================================================#获取每页双色球的信息def getText(url): for list_num in range(1,getPageNum(url)):#从第一页到第getPageNum(url)页 print list_num#打印下页码 href = 'http://kaijiang.zhcw.com/zhcw/html/ssq/list_'+str(list_num)+'.html' #调用新url链接 # for listnum in len(list_num): page = BeautifulSoup(getPage(href)) em_list = page.find_all('em')#匹配em内容 div_list = page.find_all('td',{'align':'center'})#匹配 <td align=center>这样的内容#初始化n n = 0#将双色球数字信息写入num.txt文件 fp = open("num.txt" ,"w") for div in em_list: emnum1 = div.get_text() # print emnum1 text = div.get_text() text = text.encode('utf-8') #print title n=n+1 if n==7: text = text + "\n" n=0 else: text = text + "," fp.write(str(text)) fp.close()#将日期信息写入date.txt文件 fp = open("date.txt" ,"w") for div in div_list: text = div.get_text().strip('') # print text list_num = re.findall('\d{4}-\d{2}-\d{2}',text) list_num = str(list_num[::1]) list_num = list_num[3:13] if len(list_num) == 0: continue elif len(list_num) > 1: fp.write(str(list_num)+'\n') fp.close()#将num.txt和date.txt文件进行整合写入hun.txt文件中#格式如下:#('2016-05-03', '09,12,24,28,29,30,02')#('2016-05-01', '06,08,13,14,22,27,10')#('2016-04-28', '03,08,13,14,15,30,04')# fp01 = open("date.txt","r") a=[] for line01 in fp01: a.append(line01.strip('\n')) # print a fp01.close() fp02 = open("num.txt","r") b=[] for line02 in fp02: b.append(line02.strip('\n')) # print b fp02.close() fp = open("hun.txt" ,"a") for cc in zip(a,b):#使用zip方法合并 print cc fp.write(str(cc) + '\n') fp.close()#===============================================================================if __name__=="__main__": pageNum = getPageNum(url) print pageNum getpagetext = getText(url) print getpagetext
数据样例:
('2015-03-03', '09,11,16,18,23,24,10')
('2015-03-01', '08,09,10,13,29,30,01')
('2015-02-26', '04,07,10,16,23,25,10')
0 0
- python数据分析1:获取双色球历史信息
- python数据分析(1)——获取微信好友的统计信息
- 利用 Python 获取余额宝历史收益数据
- python历史天气采集分析
- [python]解析通达信盘后数据获取历史日线数据
- [python]解析通达信盘后数据获取历史日线数据
- Hadoop 历史服务器获取作业运行信息
- Python数据分析-1
- Python数据分析1
- python数据分析1
- python数据分析1
- 获取历史天气数据,数据挖掘必备
- 【Python 量化投资系列】python3 获取基金及历史净值数据
- [Python]利用ricequant获取上证指数以及所有股票历史价格数据
- 使用Spark分析拉勾网招聘信息(二): 获取数据
- 用python获取气象数据开放平台信息
- Python金融大数据分析-数据获取与简单处理
- Python爬虫之实习僧招聘信息及数据分析
- jquery validate 对动态表单元素添加校验
- Android EventBus
- Java Servlet(一)
- 【Unix网络编程】socket函数与描述符
- Leetcode 242. Valid Anagram
- python数据分析1:获取双色球历史信息
- 制作Ubuntu系统做成LiveCD iso
- request对象JSP学习
- jQuery学习和知识点总结归纳
- android studio配置
- 如何查看Linux是32位还是64位(转)
- 人工智能过去60年沉浮史,未来60年将彻底改变人类
- 正则表达式学习笔记(4) 贪婪、惰性和支配量词
- String、动态规划——wildcard-matching 通配符匹配