主页 > 华为手机怎么安装imtoken > 比特币历史数据 - 使用 Python 从交易平台获取数据
比特币历史数据 - 使用 Python 从交易平台获取数据
根据相关政策法规,国内比特币交易将于2017年9月下旬关闭,但过去几年比特币交易的历史行情数据可能对未来经济、金融、量化交易研究具有重要价值策略。因此,本文主要介绍如何通过Python从交易平台提供的API中获取数据比特币历史行情数据,并将其保存为CSV文件以备后用。
本文主要内容如下:
比特币、莱特币历史市场数据
已获取比特币、莱特币等多种数字货币的历史行情数据,并以csv格式保存。需要数据的人可以直接从 GitHub 下载使用。GitHub上也提供了数据采集的源代码。如果你想知道数据源可以阅读源代码。备注:以下数据来源于网络,源代码已公开。不保证数据的准确性比特币历史行情数据,请根据实际情况使用。
目标交换数据的下载地址
1
btc_cny
好币
daily_price_btc_cny.csv
2
ltc_cny
好币
daily_price_ltc_cny.csv
3
eth_cny
好币
daily_price_eth_cny.csv
4
etc_cny
好币
daily_price_etc_cny.csv
5
bcc_cny
好币
daily_price_bcc_cny.csv
6
btc_cny
火币
daily_price_btc_cny.csv
7
ltc_cny
火币
daily_price_ltc_cny.csv
使用 Python 从 okcoin.cn 获取比特币历史数据
我们可以参考okcoin提供的API手册来获取历史行情数据。
获取历史数据主要有两个步骤:
import http.client
import json
import pandas as pd
REQUEST_URL = 'www.okcoin.cn'
KLINE_TT_COLS = ['date', 'open', 'high', 'low', 'close', 'volume']
def http_get(url, resource, params=''):
conn = http.client.HTTPSConnection(url, timeout=10)
conn.request("GET", resource + '?' + params)
response = conn.getresponse()
data = response.read().decode('utf-8')
return json.loads(data)
def ticker(symbol='', data_type='1day', since=''):
ticker_resource = "/api/v1/kline.do"
params = ''
if symbol:
params = 'symbol=%(symbol)s&type=%(type)s' % {'symbol': symbol, 'type': data_type}
if since:
params += '&since=%(since)s' % {'since': since}
k_data = http_get(REQUEST_URL, ticker_resource, params)
if len(k_data) == 0:
raise ValueError('Can not obtain the data.')
else:
df = pd.DataFrame(k_data, columns=KLINE_TT_COLS)
df['date'] = pd.to_datetime(df['date'], unit='ms')
return df
if __name__ == '__main__':
# okcoin.cn bitcoin - cny since 2013-6-11 ~ now, daily price history
daily_price_btc_cny = ticker('btc_cny')
daily_price_btc_cny.to_csv('./data/okcoin/daily_price_btc_cny.csv')
# okcoin.cn litecoin - cny since 2013-9-11 ~ now daily price history
daily_price_ltc_cny = ticker('ltc_cny')
daily_price_ltc_cny.to_csv('./data/okcoin/daily_price_ltc_cny.csv')
# okcoin.cn eth - cny since 2017-5-31 ~ now daily price history
daily_price_eth_cny = ticker('eth_cny')
daily_price_ltc_cny.to_csv('./data/okcoin/daily_price_eth_cny.csv')
# okcoin.cn etc - cny since 2017-7-16 ~ now daily price history
daily_price_etc_cny = ticker('etc_cny')
daily_price_etc_cny.to_csv('./data/okcoin/daily_price_etc_cny.csv')
# okcoin.cn bcc - cny since 2017-7-16 ~ now daily price history
daily_price_bcc_cny = ticker('etc_cny')
daily_price_bcc_cny.to_csv('./data/okcoin/daily_price_bcc_cny.csv')
# okcoin.cn bitcoin - cny since 2013-6-11 ~ now, hour price history
hour_price_btc_cny = ticker(symbol='btc_cny', data_type='1hour')
hour_price_btc_cny.to_csv('./data/okcoin/hour_price_btc_cny.csv')
# okcoin.cn litecoin - cny since 2013-6-11 ~ now, hour price history
hour_price_ltc_cny = ticker(symbol='ltc_cny', data_type='1hour')
hour_price_ltc_cny.to_csv('./data/okcoin/hour_price_ltc_cny.csv')
使用 Python 从 huobi.com 获取比特币历史数据
类似于从okcoin.cn获取历史数据,请参考火币网提供的API手册。详细代码如下:
import http.client
import json
import pandas as pd
REQUEST_URL = 'api.huobi.com'
KLINE_TT_COLS = ['date', 'open', 'high', 'low', 'close', 'volume']
def http_get(url, resource, params=''):
conn = http.client.HTTPSConnection(url, timeout=10)
conn.request("GET", resource + '?' + params)
response = conn.getresponse()
data = response.read().decode('utf-8')
return json.loads(data)
def ticker(symbol=''):
ticker_resource = "/staticmarket/%(symbol)s_kline_100_json.js" % {'symbol': symbol}
params = ''
if symbol:
params = 'length=2000'
k_data = http_get(REQUEST_URL, ticker_resource, params)
if len(k_data) == 0:
raise ValueError('Can not obtain the data.')
else:
df = pd.DataFrame(k_data, columns=KLINE_TT_COLS)
df['date'] = pd.to_datetime(df['date'], format="%Y%m%d%H%M%S%f")
return df
if __name__ == '__main__':
# huobi.com bitcoin - cny since 2013-9-1 ~ now, daily price history
daily_price_btc_cny = ticker('btc')
daily_price_btc_cny.to_csv('./data/huobi/daily_price_btc_cny.csv')
# huobi.com litecoin - cny since 2014-3-9 ~ now daily price history
daily_price_ltc_cny = ticker('ltc')
daily_price_ltc_cny.to_csv('./data/huobi/daily_price_ltc_cny.csv')
参考
Okcoin API
火币API
GitHub