Request to review the simple query that client wrote & optimize it

Request to review the simple query that client wrote & optimize it
ds = dsweb.DataClient(username = auth_info['secrets'][1]['key'], password = auth_info['secrets'][1]['value'])
# Golbal parameters
start_date = '2008-01-01'
# Listing of instruments per dataset
instruments = {
'energy' : 'ETQC.01,LNGASIA,NATGAS1,LLCC.01',
'FX' : 'USAFGHN,TDALLSP,TDDZDSP,TDAOASP,USARGEN,USARMEN,TDAWGSP,MSERAUD,TDAZNSP,BAHRDI$,USBAHDN,BANTAK$,TDBBDSP,TDBYNSP,TDBZDSP,BERMDO$,BOLIPE$,TDBAMSP,BOTSWPI,USBRAZL,BRUNDO$,BLUSDSP,TDBIFSP,TDXPFSP,TDKHRSP,MSERCAD,TDCVESP,CAYIDO$,TDXAFSP,CDIVCF$,USCHILP,USCHINY,USCOLMP,TDKMFSP,TDCDFSP,TDCRCSP,TDCUPSP,USCZECK,MSERDKK,TDDJFSP,TDDOPSP,TDXCDSP,TDEGPSP,TDERNSP,TDETBSP,EUDOLLR,TDFJDSP,TDGMDSP,TDGELSP,TDGHSSP,TDGTQSP,TDGNFSP,USGUYAN,TDHTGSP,TDHNLSP,MSERHKD,HNUSDNB,ICUSDSP,USINDNR,USINDON,TDIRRSP,TDIQDSP,ISUSDSP,TDJMDSP,MSERJPY,USJORDR,TDKZTSP,TDKESSP,USKUWTD,TDKGSSP,TDLAKSP,TDLBPSP,TDLRDSP,TDLYDSP,TDMOPSP,TDMGASP,TDMWKSP,USMALAY,TDMVRSP,TDMRUSP,TDMURSP,USMEXPF,TDMDLSP,TDMNTSP,MOROCD$,TDMZNSP,TDMMKSP,TDNADSP,TDNPRSP,TDANGSP,TDUSESP,MSERNZD,TDNIOSP,NIGNAI$,TDMKDSP,MSERNOK,TDOMRSP,USPAKIS,PAPUAK$,TDPYGSP,USPERUI,PHUSDSP,USPOLZL,TDQARSP,TDRONSP,RSUSD.X,TDRWFSP,WESTSAI,TDSTNSP,USSAUDR,TDRSDSP,TDSCRSP,MSERSGD,SOLOMOI,TDSOSSP,BBZARSP,KOUSDSP,SSPUSSP,SPEDRAW,MSERLKR,TDSDGSP,TDUSRDP,TDSZLSP,MSERSEK,MSERCHF,TDSYPSP,USTAIWD,TAJIKS$,TDTZSSP,USTHAIB,TONGAPI,TDTTDSP,TDTNDSP,TKUSDSP,TDTMMSP,TDUGXSP,TDUAHSP,USUTDAD,UKDOLLR,USURUGP,TDUZSSP,VANUAT$,USVENBS,TDVNDSP,YEMENR$,TDZMKSP,TDZWDSP,USG6WIC',
'stocks' : "XGLFLD$,S&PCOMP,MSWRLD$,MSEMKF$,MSEROP$,MSEAFE$,MSPACF$,S&PCOMP,DAXINDX,FTSE100,FRCAC40,HNGKNGI,KORCOMP,CHSASHR"
}
# Collecting data
data = {}
missing_indicators = {}
for ds_name in instruments.keys():
print(ds_name)
if len(instruments[ds_name].split(",")) <= 50:
data[ds_name] = ds.get_data(tickers=instruments[ds_name], start=start_date, freq='D')
else:
instru_split = [instruments[ds_name].split(",")[i:i + 50] for i in range(0, len(instruments[ds_name].split(",")), 50)]
df_list = []
for instru_chunk in instru_split:
df_list.append(ds.get_data(tickers=",".join(instru_chunk), start=start_date, freq='D'))
data[ds_name] = pd.concat(df_list, axis = 1)
# Checking missing indicators
instrument_requested = instruments[ds_name].split(",")
instruments_covered = data[ds_name].columns.get_level_values('Instrument')
missing_indicators[ds_name] = list(set(instrument_requested) - set(instruments_covered))
Categories
- All Categories
- 3 Polls
- 6 AHS
- 37 Alpha
- 167 App Studio
- 6 Block Chain
- 4 Bot Platform
- 18 Connected Risk APIs
- 47 Data Fusion
- 34 Data Model Discovery
- 709 Datastream
- 1.5K DSS
- 633 Eikon COM
- 5.2K Eikon Data APIs
- 16 Electronic Trading
- 1 Generic FIX
- 7 Local Bank Node API
- 8 Trading API
- 3K Elektron
- 1.5K EMA
- 260 ETA
- 571 WebSocket API
- 41 FX Venues
- 16 FX Market Data
- 2 FX Post Trade
- 1 FX Trading - Matching
- 12 FX Trading – RFQ Maker
- 5 Intelligent Tagging
- 2 Legal One
- 26 Messenger Bot
- 4 Messenger Side by Side
- 9 ONESOURCE
- 7 Indirect Tax
- 60 Open Calais
- 285 Open PermID
- 48 Entity Search
- 2 Org ID
- 1 PAM
- PAM - Logging
- 6 Product Insight
- Project Tracking
- ProView
- ProView Internal
- 25 RDMS
- 2.3K Refinitiv Data Platform
- 17 CFS Bulk File/TM3
- 909 Refinitiv Data Platform Libraries
- 5 LSEG Due Diligence
- 1 LSEG Due Diligence Portal API
- 4 Refinitiv Due Dilligence Centre
- Rose's Space
- 1.2K Screening
- 18 Qual-ID API
- 13 Screening Deployed
- 23 Screening Online
- 12 World-Check Customer Risk Screener
- 1K World-Check One
- 46 World-Check One Zero Footprint
- 45 Side by Side Integration API
- 2 Test Space
- 3 Thomson One Smart
- 10 TR Knowledge Graph
- 151 Transactions
- 143 REDI API
- 1.8K TREP APIs
- 4 CAT
- 27 DACS Station
- 126 Open DACS
- 1.1K RFA
- 108 UPA
- 197 TREP Infrastructure
- 232 TRKD
- 923 TRTH
- 5 Velocity Analytics
- 9 Wealth Management Web Services
- 106 Workspace SDK
- 11 Element Framework
- 5 Grid
- 19 World-Check Data File
- 1 Yield Book Analytics
- 48 中文论坛