Skip to content

GreenGrassBlueOcean/RefinitivR

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Important messages:

You can now use both Eikon and Workspace. The package only supports a desktop session not platform sessions. This is theoretically possible but currently not implemented.

  1. Python is now optional, the package can now also send direct JSON messages to the terminal.
  2. When using the pyton libraries and if you update the package: also run Refinitiv::install_eikon() again.
  3. Python Eikon and RDP libraries are depricated and can no longer be used. The current commit of the package is reverse compatible with previous commits.

Codecov test coverage R build status

RefinitivR

An R interface to Refinitv Eikon and Refinitiv DataStream.

RefinitivR is an R interface to Refinitiv Eikon by using direct JSON messages or the reticulate package (Python Eikon/RDP api). It also provides access to DataStream using the DatastreamDSWS2R package. This package is in no way affiliated with Thomson Reuters,Refinitv, Eikon, Datastream or LSEG. A subscription to EIkon and Datastream is required to use this package. Use of the package is at own risk! This package uses the DatastreamDSWS2R package from CharlesCara (https://github.com/CharlesCara/DatastreamDSWS2R) for the DataStream Connections.

The reason that this package was developed is that the existing eikonapir package has stability issues leading to dropped api calls. This package gives multiple options for connecting with the Refinitiv API and retries also dropped api calls which will result in a much more stable api connection. Furthermore the package tries to be as robust as possible by automatically chunking long requests in api limit compliant pieces and retries failed requests in order to overcome http 400 errors.

An interface to the R datastream package DatastreamDSWS2R is also provided to allow for easy retrieval of information so that both Eikon and Datastream commands can be used from a single r package.

install.packages("devtools")
devtools::install_github("GreenGrassBlueOcean/RefinitivR")

load the package

library(Refinitiv)

Connecting to Refinitiv directly

When using the direct JSON method no python installation is necessary:

Eikon <- EikonConnect(Eikonapplication_id = "YOUR EIKON API KEY", PythonModule = "JSON")
RD <- RDConnect(application_id =  "YOUR API KEY",  PythonModule = "JSON")

Connecting to Refinitiv Eikon through the official Refinitiv python API

If one wants to use the Python RD Packages: Install the reticulate MiniConda environment r-eikon so that the python module RD can be used by the r-package.

Installation of the python packages (Run Rstudio with elevated permissions or as Administrator for the installation of the python libraries)

Refinitiv::install_eikon()
Eikon <- EikonConnect(Eikonapplication_id = "YOUR EIKON API KEY", PythonModule = "RD")
RD <- RDConnect(application_id =  "YOUR API KEY",  PythonModule = "RD")

Working with Refintiv Data (RD) libraries

Connecting:

(make sure that Eikon/LSEG WorkSpace is running and online)

 RD <- RDConnect('your api key', PythonModule = "JSON")

or when you have installed the python environment using Refinitiv::install_eikon() you can also use:

 RD <- RDConnect('your api key', PythonModule = "RD")

Searching:

 test <- RDPsearch(RD, query =  "AAPL.O")
 test <- RDPsearch(RD, query =  "AAPL.O", select = "ContractType,RIC")

 Presidents <- RDPsearch( RD, view = "People", query = 'president'
                        , filter = "startswith(LastName,'H')"
                        , select = 'DocumentTitle'
                        , boost = ''
                        , order_by = 'DocumentTitle asc'
                        , group_by = 'FirstName'
                        , group_count = 2
                        , top = 20
                        )

Get History

timeseries1 <-  rd_GetHistory(RDObject = RD, universe=c("AAPL.O", "NVDA.O"))

Datarequest <- rd_GetHistory( RDObject = RD, universe = c("GOOG.O","AAPL.O")
                            , fields = c("TR.Revenue","TR.GrossProfit")
                            , parameters = list("SDate" = "0CY", "Curn" = "CAD")
                            )

Get Data

ex1 <- rd_GetData( RDObject = RD, rics = c("MMM", "III.L")
                 , Eikonformulas = c( "TR.PE(Sdate=0D)/*P/E (LTM) - Diluted Excl*/"
                                    , "TR.CompanyName")
                 , verbose = TRUE
                 )

 ex2 <- rd_GetData( RDObject = RD, rics = "AAPL.O"
                  , Eikonformulas = "TR.CompanyMarketCap(Sdate=0D)/*Market Cap*/"
                  )

Historical timeseries

Intraday Timeseries

# Daily - Count
Intraday_vod <- rd_GetHistoricalPricing( universe = "VOD.L", interval = "P1D"
                                       , count = 20L, RDObject = RD)

Interday Timeseries

# 1 minute - Count - All Sessions
Vodafone <- rd_GetHistoricalPricing( universe = c("VOD.L", "AAPL.O")
                                   , interval = "PT1M", count = 500L
                                   , sessions= c("pre","normal","post")
                                   , RDObject = RD
                                   )

Custom Instruments

Connecting for Custom Instruments

  1. Custom Instruments can only be created using JSON connection method.
  2. UUID Parameter: Eikon UUID can be found here: Eikon Terminal --> help --> about --> user details: UUID e.g. ABCDE-123456
RDConnect(application_id = NA, PythonModule = "JSON", UUID = "ABCDE-123456")

Create a Simple Instrument:

rd_ManageCustomInstruments( operation = "CREATE", symbol = "testAAPLandAMZN"
                          , formula = "AAPL.O + AMZN.O")

Get instrument details

rd_ManageCustomInstruments(operation = "GET", symbol = "testAAPLandAMZN")

Update Instrument formula

rd_ManageCustomInstruments( operation = "UPDATE", symbol = "testAAPLandAMZN"
                          , formula = "AAPL.O + 2 * AMZN.O")

Delete

rd_ManageCustomInstruments(operation = "DELETE", symbol = "testAAPLandAMZN")

Build a custom instrument out of a basket of instruments

Build the basket:

basket <- CustomInstrumentBasketBuilder(RICs = c("AAPL.O", "AMZN.O"), Weights = c(0.5, 0.5))

Create a custom instrument with the basket":

rd_ManageCustomInstruments(operation = "CREATE", symbol = "InterestingBasket",
                               basket = basket, currency = "USD")

Create holidays for the instrument:

holidays <-  CustomInstrumentHolidayBuilder( dates = c("2023-12-01", "2023-12-31")
                                           , reasons = c("Special Bank Holiday 1"
                                                       , "Special Bank Holiday 2")
                                           )

Update the basket with some holidays:

rd_ManageCustomInstruments(operation = "UPDATE", symbol = "InterestingBasket",
                           holidays = holidays )

Delete instrument:

rd_ManageCustomInstruments(operation = "DELETE", symbol = "InterestingBasket")

Useful add on functions

List all created and active custom instruments:

AllActiveCustomInstruments <- rd_SearchCustomInstruments()

Custom instruments come in very specific RIC format. To ease the use of the package RefinitivR create this specific format for you. The following formula allows to retrieve the official custom instrument name (RIC).

RealInstrumentName <- CorrectCustomInstrument("InterestingBasket")

OMM streaming (beta version will still change in future)

Create streaming object

OMM_ws <- create_OMM_Stream()
EUR_stream <- OMM_ws$new(name = "EUR=", fields = c("BID","ASK","OPEN_PRC"))
# start stream
EUR_stream$connect()
# stop stream
EUR_stream$close()

Working with the Legacy Eikon functions

Connecting

(make sure that Eikon/LSEG WorkSpace is running and online)

  Eikon <- EikonConnect(Eikonapplication_id = "YOUR EIKON API KEY", PythonModule = "JSON")

or when you have installed the python environment using Refinitiv::install_eikon() you can also use:

 Eikon <- EikonConnect(Eikonapplication_id = "YOUR EIKON API KEY", PythonModule = "RD")

Getting News Stories

Scan the headlines

headlines <- EikonGetNewsHeadlines( EikonObject = Eikon
                                   , query = "R:MSFT.O", count = 2)

Get the news stories

stories <- EikonGetNewsStory(story_id = headlines$storyId, EikonObject = Eikon)

Performing a timeseries request

Timeseries <- EikonGetTimeseries( EikonObject = Eikon, rics = c("MMM", "III.L"),
                                , start_date = "2020-01-01T01:00:00",
                                , end_date = paste0(Sys.Date(), "T01:00:00")
                                )

Performing a request for a monthly economic timeseries

  EconTimeSeries <- EikonGetTimeseries( EikonObject = Eikon
                                      , rics = "USCPI=ECI"
                                      , interval = "monthly"
                                      , fields = c()
                                      , start_date = "2020-01-01T01:00:00",
                                      , end_date = paste0(Sys.Date(), "T01:00:00")
                                      )

Performing a data request

Data <- EikonGetData(EikonObject = Eikon, rics = c("MMM", "III.L"),
                     Eikonformulas = c("TR.PE(Sdate=0D)/*P/E (LTM) - Diluted Excl*/", "TR.CompanyName"))

Retrieving large integers with EikonGetData (Python only, not for JSON method)

There is currently an issue with the reticulate package handling large integers (like e.g. market capatilization) from python to r. This issue is described here and try for yourself here

This leads to the following behaviour:

ex2 <- EikonGetData( EikonObject = Eikon, rics = "AAPl.O"
                    , Eikonformulas = "TR.CompanyMarketCap(Sdate=0D)/*Market Cap*/"
                    )

ex2 will return -1 for the Market capitalization. Which can never be the correct number. A workaround is to scale back the expected output to a smaller number. By expressing the market capatalization in millions the produced integer becomes smaller and so prevents the integer of becoming too large. This can be done by adding a named list in the parameters field: Parameters = list("scale" = 6) in which the 6 stands for millions.

ex2a <- EikonGetData( EikonObject = Eikon, rics = "AAPl.O"
                    , Eikonformulas = "TR.CompanyMarketCap(Sdate=0D)/*Market Cap*/"
                    , Parameters = list("scale" = 6)
                    )

Or for more complex formula's scale back in the formula itself by adding scale = 6 to TR.CompanyMarketCap

ex2b <- EikonGetData( EikonObject = Eikon, rics = "AAPl.O"
                    , Eikonformulas = "TR.CompanyMarketCap(Sdate=0D, scale=6)/*Market Cap*/"
                    )

DataStream

DatastreamUserName <- "Your datastream username"
DatastreamPassword <- "Your datastream password"
DataStream <- DataStreamConnect(DatastreamUserName, DatastreamPassword)

DSResult <- DataStream$snapshotRequest(instrument = c("ABF","RIO","WPP"),
                                       datatype = "P",
                                       requestDate = "0D")

For further details on accessing datastream see https://github.com/CharlesCara/DatastreamDSWS2R.

licensing see LICENSE File!

About

an R interface to Refinitv Eikon and Refinitiv DataStream

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages