CryptowatchというサイトのAPIを使用し、
bitflyerという取引所から過去のローソク足データを取得したく。
下記コード(1分足のローソク足データを取得)を実行したところ、
★で、10日前からの1分足ローソク足データを指定したにも関わらず
一度に約6000程度(= つまり4日分程度)の1分足ローソク足データしかCSV保存できません。
取引所のデータベース上に存在する すべての 1分足ローソク足のデータ(つまり、存在する最古のデータ~現在のデータ)
を取得するには
どのようにコードを書き換えればよいでしょうか。
是非アドバイスをお願いいたします。
ちなみに、cryptowatchのAPI使用方法については、こちらのQiitaに掲載されています。
import requests import time import pandas as pd from datetime import datetime # ************************************************************************* # 関数ローソク足のOpen, High, Low, Closeを取得する関数 def get_OHLC(before, after): url = 'https://api.cryptowat.ch/markets/bitflyer/btcjpy/ohlc' query = { 'periods': 60, 'before': before, 'after': after, } res = requests.get(url, params=query).json()['result']['60'] return res # unixtime(ミリ秒)を日時に変換 def convert_unix(unixtime): return datetime.fromtimestamp(unixtime) unixTime = lambda y, m, d, h: int(time.mktime(datetime(y, m, d, h).timetuple())) now = datetime.now() y, m, d, h = now.year, now.month, now.day, now.hour data = get_OHLC(unixTime(y, m, d, h), unixTime(y, m, d - 10, h)) ★ print(data) Time, Open, High, Low, Close, Volume, UTCTime = [], [], [], [], [], [], [] # ************************************************************************* # Unix→UTCへ変換 unix = [x[0] for x in data] print("unix : ", unix) YYYYMMDD = [] for j in unix: yyyymmdd = convert_unix(j) print(str(yyyymmdd)) YYYYMMDD.append(str(yyyymmdd)) print(YYYYMMDD) for i in data: # print(i) Time.append(i[0]) Open.append(i[1]) High.append(i[2]) Low.append(i[3]) Close.append(i[4]) Volume.append(i[5]) UTCTime.append(i[6]) pd.DataFrame({'time': Time, 'open': Open, 'high': High, 'low': Low, 'close': Close, 'volume': Volume, 'UTCTime': YYYYMMDD}).to_csv('price.csv')
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/09/26 08:00