Yahoo! Finance财经数据PYTHON临时读取方法
本篇文章转自简书:http://www.jianshu.com/p/85d563d326a9
这段时间在看量化策略,找到了一个比较不错的开源项目,但是yahoo金融的数据源一直没有找到,在网上找到了这篇文章,分享一下。文章最下方是原作者的微信号,有想打赏的自便~~
Yahoo! Finance提供国内外财经数据,PYTHON通常借助于pandas或者matplotlib进行数据读取。
由于2017年5月16日Yahoo!单方面进行了API升级,原数据接口已下线。
原URL格式:https://chart.yahoo.com/table.csv?s=IBM
现调整为:https://query1.finance.yahoo.com/v7/finance/download/IBM?period1=1492611801&period2=1495203801&interval=1d&events=history&crumb=NMhMTCv7QpM
在pandas及matplotlib yahoo finance补丁发布前,可通过本文提供的临时解决方法提取数据。
原数据提取方法一:
import pandas.io.data as web
IBMStock = web.DataReader(name="IBM", data_source="yahoo",start="2000-1-1")
原数据提取方法二:
import requests
s = requests.Session()
r = s.get("https://chart.yahoo.com/table.csv?s=IBM",verify=False)
原数据提取方法三:
from matplotlib.finance import quotes_historical_yahoo_ochl
date1=(2013, 1, 1)
date2=(2013, 12,31)
price=quotes_historical_yahoo_ochl('IBM', date1, date2)
PYTHON临时解决方案:
Step1. 通过浏览器获取访问yahoo时的cookie值
https://finance.yahoo.com/quote/IBM/history?p=IBM
Chrome
Step2. 右键点击download,取得crumb值
Step3. 使用unix time替换起止日期
代码示例(Python 2.7.13 |Anaconda 4.3.1 (64-bit)):
# -*- coding: utf-8 -*-
"""
Created on Fri May 19 2017
@author: vincentqiao
"""
import requests
import time
import pandas as pd
import matplotlib.pyplot as plt
def datetime_timestamp(dt):
     time.strptime(dt, '%Y-%m-%d %H:%M:%S')
     s = time.mktime(time.strptime(dt, '%Y-%m-%d %H:%M:%S'))
     return str(int(s))
s = requests.Session()
#Replace B=xxxx
cookies = dict(B='c650m5hchrhii&b=3&s=tk')
#Replace crumb=yyyy
crumb = 'NMhMTCv7QpM'
begin = datetime_timestamp("2014-01-01 09:00:00")
end = datetime_timestamp("2017-04-30 09:00:00")
r = s.get("https://query1.finance.yahoo.com/v7/finance/download/IBM?period1="+begin+"&period2="+end+"&interval=1d&events=history&crumb="+crumb,cookies=cookies,verify=False)
f = open('IBM.csv', 'w')
f.write(r.text)
f.close()    
es = pd.read_csv('IBM.csv', index_col=0,parse_dates=True, sep=",", dayfirst=True)
data = pd.DataFrame({"IBM" : es["Adj Close"][:]}) 
print(data.info())
data.plot(subplots=True, grid=True, style="b", figsize=(8, 6))
plt.show()
运行结果:

作者微信公众号
Yahoo! Finance财经数据PYTHON临时读取方法的更多相关文章
- python 文件读取方法详解
		
话不多说直接码 # 绝对路径 # f = open('/Users/fangxiang/Downloads/我的古诗.text', mode='r', encoding='utf-8') # cont ...
 - Python下载Yahoo!Finance数据
		
Python下载Yahoo!Finance数据的三种工具: (1)yahoo-finance package. (2)ystockquote. (3)pandas.
 - Delphi中使用python脚本读取Excel数据
		
Delphi中使用python脚本读取Excel数据2007-10-18 17:28:22标签:Delphi Excel python原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 . ...
 - 第十二节,TensorFlow读取数据的几种方法以及队列的使用
		
TensorFlow程序读取数据一共有3种方法: 供给数据(Feeding): 在TensorFlow程序运行的每一步, 让Python代码来供给数据. 从文件读取数据: 在TensorFlow图的起 ...
 - PHP file_get_contents函数读取远程数据超时的解决方法
		
PHP file_get_contents函数读取远程数据超时的解决方法 投稿:junjie 字体:[增加 减小] 类型:转载 这篇文章主要介绍了PHP file_get_contents函数读取 ...
 - python之xml 文件的读取方法
		
''' xml 文件的读取方法 ''' #!/usr/bin/env python # -*- coding: utf- -*- import xml.etree.ElementTree as ET ...
 - python 爬虫数据存入csv格式方法
		
python 爬虫数据存入csv格式方法 命令存储方式:scrapy crawl ju -o ju.csv 第一种方法:with open("F:/book_top250.csv" ...
 - Python财经数据接口包TuShare的使用
		
安装TuShare 方式1:pip install tushare 方式2:访问https://pypi.python.org/pypi/tushare/下载安装 方式3:将源代码下载到本地pytho ...
 - python之读取yaml数据
		
一.yaml简介 yaml:一种标记语言,专门用来写配置文件. 二.yaml基础语法 区分大小写: 使用缩进表示层级关系: 使用空格键缩进,而非Tab键缩进 缩进的空格数目不固定,只需要相同层级的元素 ...
 
随机推荐
- python开发之路目录
			
Python 目录 基础 python入门 python数据类型.字符编码.文件处理 python函数基础 python函数进阶 python装饰器函数 python装饰器函数 python递归函数 ...
 - 4.1 Routing -- Introduction
			
一.Routing 1. 当用户与应用程序交互时,它会经过很多状态.Ember.js为你提供了有用的工具去管理它的状态和扩展你的app. 2. 要理解为什么这是重要的,假设我们正在编写一个Web应用程 ...
 - (2)Mac环境搭建
			
创建HelloWorld项目 将刚才下载的压缩包解压到你指定的文件夹里. 进入到目录cocos2d-x-3.2alpha0/tools/cocos2d-console/bin/cocos.py 打开终 ...
 - 给iphone配置qq邮箱
			
在手机上使用qq邮箱发送和接受邮件,但是又不用qq邮箱,我用的是“网易邮箱大师” ,那么就需要配置服务. 1.在qq邮箱中设置邮箱,开启相关的服务,然后用手机发送短信来生成授权码.最后在手机上设置的密 ...
 - Java transient关键字的理解
			
transient [ˈtrænziənt] adj. 短暂的; 转瞬即逝的; 临时的 n 临时旅客; 瞬变现象; 候鸟; 1. transient的作用及使用方法 我们都知道一个对象只要 ...
 - 【运维技术】Nginx安装教程(yum安装,源码编译)
			
安装方式 yum直接更新源安装 源码直接编译之后安装 使用yum进行直接安装 Installing a Prebuilt CentOS/RHEL Package from an OS Reposito ...
 - 【运维技术】CentOS7上从零开始安装阿里RocketMQ版本:release-4.0.1【亲测哈哈】
			
CentOS7上从零开始安装阿里RocketMQ版本:release-4.0.1[亲测哈哈] 安装git # 更新包 $ yum update # 安装git $ yum install git # ...
 - Python笔记 #04# Methods
			
源:DataCamp datacamp 的 DAILY PRACTICE + 日常收集. Methods String Methods List Methods 缺一 Methods You can ...
 - JS中的slice和splice
			
1,slice : 定义:接收一个或两个参数,它可以创建一个由当前数组中的一项或多项组成的新数组,注意是新数组哦~ 也就是说它不会修改原来数组的值. 用法:slice( para1 ),会截取从pa ...
 - 20145301赵嘉鑫《网络对抗》逆向及Bof基础
			
20145301赵嘉鑫<网络对抗>逆向及Bof基础 实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数会简单回 ...