python抓取汇率
# -*- coding: utf-8 -*-
"""
获取实时汇率
Created on Fri Oct 18 13:11:40 2013 @author: alala
""" import httplib
import re
import MySQLdb
import datetime URL = 'fx.cmbchina.com' #网站名
PATH = '/hq/' #页面路径
HOST = 'localhost' #数据库地址(ip)
DB = "money" #数据库名称
USER = 'root' #数据库用户名
PSWD = 'sheet' #数据库密码 httpClient = None try:
#抓去网页内容
httpClient = httplib.HTTPConnection(URL, 80, timeout=30)
httpClient.request('GET', '/hq/')
response = httpClient.getresponse()
html = response.read()
#print html #用正则表达式抓去汇率数据
reg = re.compile(r"""
<tr>\s*<td\s+class="fontbold">\s*(?P<name>\S+)\s*</td>\s* #交易币
<td\s+align="center">\s*(?P<unit>\d+)\s*</td>\s* #交易币单位
<td\s+align="center"\s+class="fontbold">\s*(?P<base>\S+)\s*</td>\s* #基本币
<td\s*class="numberright">\s*(?P<midPrice>\d+\.\d+)\s*</td>\s* #中间价
<td\s*class="numberright">\s*(?P<sellPrice>\d+\.\d+)\s*</td>\s* #卖出价
<td\s*class="numberright">\s*(?P<buyPrice1>\d+\.\d+)\s*</td>\s* #现汇买入价
<td\s*class="numberright">\s*(?P<buyPrice2>\d+\.\d+)\s*</td>\s* #现钞买入价
<td\s*align="center">\s*(?P<time>\d+:\d+:\d+)\s*</td>\s* #时间
""", re.MULTILINE | re.X)
rows = reg.findall(html)
#打印汇率数据
for r in rows:
print ','.join(map(str,r)), '\n' #数据库操作
#确保mysqldb已经安装,可以用下面的命令安装
#pip install MySQL-python #建立和数据库系统的连接
conn = MySQLdb.connect(host=HOST, user=USER,passwd=PSWD) #获取操作游标
cursor = conn.cursor()
#执行SQL,创建一个数据库.
cursor.execute("CREATE DATABASE IF NOT EXISTS " + DB) #选择数据库
conn.select_db(DB);
#执行SQL,创建一个数据表.
cursor.execute("""CREATE TABLE IF NOT EXISTS exchange_rate(
name VARCHAR(50) COMMENT '交易币' PRIMARY KEY,
unit INT COMMENT '交易币单位',
base VARCHAR(50) COMMENT '基本币',
midPrice FLOAT COMMENT '中间价',
sellPrice FLOAT COMMENT '卖出价',
buyPrice1 FLOAT COMMENT '现汇买入价',
buyPrice2 FLOAT COMMENT '现钞买入价',
time DATETIME COMMENT '时间' ) """)
records = []
for r in rows:
(name,unit,base,midPrice,sellPrice,buyPrice1,buyPrice2,time) = r
time = datetime.datetime.strptime(datetime.datetime.now().strftime('%Y-%m-%d')
+ " " + time,'%Y-%m-%d %H:%M:%S')
record = (name,int(unit),base,float(midPrice),float(sellPrice),
float(buyPrice1),float(buyPrice2),time)
records.append(record)
#print records
#更新汇率
cursor.executemany("REPLACE exchange_rate VALUES(%s,%s,%s,%s,%s,%s,%s,%s)"
,records);
conn.commit() #关闭连接,释放资源
cursor.close(); except Exception,e:
print e
finally:
if httpClient:
httpClient.close()
python抓取汇率的更多相关文章
- Python 抓取网页并提取信息(程序详解)
最近因项目需要用到python处理网页,因此学习相关知识.下面程序使用python抓取网页并提取信息,具体内容如下: #---------------------------------------- ...
- 使用 Python 抓取欧洲足球联赛数据
Web Scraping在大数据时代,一切都要用数据来说话,大数据处理的过程一般需要经过以下的几个步骤 数据的采集和获取 数据的清洗,抽取,变形和装载 数据的分析,探索和预测 ...
- python抓取性感尤物美女图
由于是只用标准库,装了python3运行本代码就能下载到多多的美女图... 写出代码前面部分的时候,我意识到自己的函数设计错了,强忍继续把代码写完. 测试发现速度一般,200K左右的下载速度,也没有很 ...
- python抓取网页例子
python抓取网页例子 最近在学习python,刚刚完成了一个网页抓取的例子,通过python抓取全世界所有的学校以及学院的数据,并存为xml文件.数据源是人人网. 因为刚学习python,写的代码 ...
- Python抓取页面中超链接(URL)的三中方法比较(HTMLParser、pyquery、正则表达式) <转>
Python抓取页面中超链接(URL)的3中方法比较(HTMLParser.pyquery.正则表达式) HTMLParser版: #!/usr/bin/python # -*- coding: UT ...
- 如何用python抓取js生成的数据 - SegmentFault
如何用python抓取js生成的数据 - SegmentFault 如何用python抓取js生成的数据 1赞 踩 收藏 想写一个爬虫,但是需要抓去的的数据是js生成的,在源代码里看不到,要怎么才能抓 ...
- 关于python抓取google搜索结果的若干问题
关于python抓取google搜索结果的若干问题 前一段时间一直在研究如何用python抓取搜索引擎结果,在实现的过程中遇到了很多的问题,我把我遇到的问题都记录下来,希望以后遇到同样问题的童 ...
- 用python抓取智联招聘信息并存入excel
用python抓取智联招聘信息并存入excel tags:python 智联招聘导出excel 引言:前一阵子是人们俗称的金三银四,跳槽的小朋友很多,我觉得每个人都应该给自己做一下规划,根据自己的进步 ...
- python抓取月光博客的全部文章而且依照标题分词存入mongodb中
猛击这里:python抓取月光博客的全部文章
随机推荐
- linux资源监控命令详解
Linux统计/监控工具SAR详细介绍:要判断一个系统瓶颈问题,有时需要几个 sar 命令选项结合起来使用,例如: 怀疑CPU存在瓶颈,可用 sar -u 和 sar -q deng 等来查看 怀疑内 ...
- delphi中表示跳出的有break,continue, exit,abort, halt, runerror
1.break 强制退出循环(只能放在循环中),用于从For语句,while语句或repeat语句中强制退出. 2.continue 用于从For语句,while语句或repeat语句强行结束本次 ...
- Simple Shopping Cart By AngularJS
<body ng-controller='CartController'> <h1>Your Order</h1> <div ng-repeat='item ...
- 第十六章 调试及安全性(In .net4.5) 之 调试程序
1. 概述 本章内容包括 如何选择合适的构建类型.创建和管理编译指令.管理程序数据文件(pdb)和指令. 2. 主要内容 2.1 构建类型 .net中默认的两种生成模式是 发布(Release)模式 ...
- 4.html5中超链接
html中超链接都是通过<a>标签实现的,html5也不例外,这里就来探讨一下<a>标签. <a>元素属于文本元素,有一些私有属性或者叫局部属性.那么,相对应的还有 ...
- DrawTool画笔之图形笔
相关知识参考DrawTool画笔之纹理笔 , 图形笔的实现跟纹理笔的实现是一样的,重载Stroke的DrawCore方法,效果图: --------------------------------- ...
- JQuery中ajax跨域问题
var url = "http://apis.juhe.cn/idcard/index?key=e0a6277420506b2816b82f7d7821976c&cardno=&qu ...
- C 网页压力测试器
引言 <<独白>> 席慕蓉 节选一 把向你借来的笔还给你吧. 一切都发生在回首的刹那. 我的彻悟如果是缘自一种迷乱,那么,我的种种迷乱不也就只是因为一种彻悟? 在一回首间,才忽 ...
- Mysql账号管理
一 用户添加 通过insert 方式添加用户 insert into mysql.user(Host,User,Password) values("localhost"," ...
- linux log find 查询
常用的日志查询命令:find 1.从根目录开始查找所有扩展名为.log的文本文件,并找出包含”ERROR”的行: find / -type f -name "*.log" | xa ...