Get time series, start dates don't match.
Why date dont match with my query?
Yahoo finance has the data from 1998.
Tagged:
0
Best Answer
-
@pyquant Here is the generic routine:
from dateutil import parser
from datetime import timedelta
from datetime import datetime
import math
import timedef date_range(start, end, intv):
start = datetime.strptime(start,"%Y-%m-%d")
end = datetime.strptime(end,"%Y-%m-%d")
diff = (end - start ) / intv
for i in range(intv):
yield (start + diff * i).strftime("%Y-%m-%d")
yield end.strftime("%Y-%m-%d")def get_daily(rics,fields,start,end):
for ric in rics:
interval = math.ceil((parser.parse(end) - parser.parse(start)).days / 3000)
l = list(date_range(start,end,interval))
df1 = pd.DataFrame()
df = pd.DataFrame()
for i in range(interval):
ts = ek.get_timeseries(rics=ric,fields=fields, start_date=l[0+i],end_date=l[1+i], interval='daily')
df = df.append(ts)
time.sleep(0.4)
return dfrics = ['.GDAXI'] # Just for one ric at the moment I will extend this for multi-ric
fields = ['OPEN', 'HIGH', 'LOW', 'CLOSE']
start = '1990-06-04'
end = '2018-06-04'
df = get_daily(rics,fields,start,end)
dfI hope this can help.
0
Answers
-
Hi @pyquant Thanks for your question - the reason is because the timeseries API is limited to 3000 rows per interday request. You can see the limits for each in this document.
You can of course iterate these calls as you are already doing for each RIC. But you can also achieve this with 2 calls per RIC.
df1 = ek.get_timeseries(i, ['CLOSE'],start_date="1999-01-02", end_date="2008-10-22")
df2 = ek.get_timeseries(i, ['CLOSE'],start_date="2008-10-23")
df = pd.concat([df1, df2], axis=0)I hope this can help - I have a generic routine for the date calcs somewhere I will add it when i find it.
0 -
Thanks. I will give it a try.
0
Categories
- All Categories
- 6 AHS
- 39 Alpha
- 162 App Studio
- 4 Block Chain
- 5 Bot Platform
- 17 Connected Risk APIs
- 47 Data Fusion
- 30 Data Model Discovery
- 608 Datastream
- 1.3K DSS
- 577 Eikon COM
- 4.9K Eikon Data APIs
- 7 Electronic Trading
- Generic FIX
- 7 Local Bank Node API
- Trading API
- 2.7K Elektron
- 1.3K EMA
- 236 ETA
- 519 WebSocket API
- 33 FX Venues
- 10 FX Market Data
- 1 FX Post Trade
- 1 FX Trading - Matching
- 12 FX Trading – RFQ Maker
- 5 Intelligent Tagging
- 2 Legal One
- 20 Messenger Bot
- 2 Messenger Side by Side
- 9 ONESOURCE
- 7 Indirect Tax
- 59 Open Calais
- 264 Open PermID
- 39 Entity Search
- 2 Org ID
- PAM
- PAM - Logging
- 8.4K Private Comments
- 6 Product Insight
- Project Tracking
- ProView
- ProView Internal
- 20 RDMS
- 1.4K Refinitiv Data Platform
- 370 Refinitiv Data Platform Libraries
- 3 Refinitiv Due Diligence
- LSEG Due Diligence Portal API
- 3 Refinitiv Due Dilligence Centre
- Rose's Space
- 1.1K Screening
- 18 Qual-ID API
- 13 Screening Deployed
- 23 Screening Online
- 10 World-Check Customer Risk Screener
- 990 World-Check One
- 44 World-Check One Zero Footprint
- 45 Side by Side Integration API
- Test Space
- 3 Thomson One Smart
- 1.2K TR Internal
- Global Hackathon 2015
- 2 Specialists Who Code
- 10 TR Knowledge Graph
- 150 Transactions
- 142 REDI API
- 1.7K TREP APIs
- 4 CAT
- 21 DACS Station
- 117 Open DACS
- 1.1K RFA
- 103 UPA
- 172 TREP Infrastructure
- 224 TRKD
- 886 TRTH
- 5 Velocity Analytics
- 5 Wealth Management Web Services
- 60 Workspace SDK
- 9 Element Framework
- 5 Grid
- 13 World-Check Data File
- Yield Book Analytics
- 46 中文论坛