Nasdaq
Data Link
Introduction
The Data Link dataset by Nasdaq, previously known as Quandl, is a collection of alternative data sets. It has indexed millions of time-series datasets from over 400 sources, which start in different years. This dataset is delivered on several frequencies, but the free data sets have often a daily frequency.
For more information about the Data Link dataset, including CLI commands and pricing, see the dataset listing.
About the Provider
"Nasdaq" was initially an acronym for the National Association of Securities Dealers Automated Quotations. It was founded in 1971 by the National Association of Securities Dealers (NASD), now known as the Financial Industry Regulatory Authority (FINRA), with the goal to provide financial services and operate stock exchanges.
On Dec. 4th, 2018, Nasdaq announced it had acquired Quandl, Inc., a leading provider of alternative and core financial data. Quandl was founded by Tammer Kamel in 2012, with goal of making it easy for anyone to find and use high-quality data effectively in their professional decision-making. In 2021, Quandl was replaced by Nasdaq Data Link.
Getting Started
The following snippet demonstrates how to request data from the Data Link dataset:
from QuantConnect.DataSource import * # For premium datasets, provide your API Key # NasdaqDataLink.set_auth_code(self.get_parameter("nasdaq-data-link-api-key")) self.bitcoin_chain_symbol = self.add_data(NasdaqDataLink, "QDL/BCHAIN", Resolution.DAILY).symbol # This dataset has one data column ("Value") self.bitfinex_exchange_rate_symbol = self.add_data(NasdaqCustomColumns, "QDL/BITFINEX", Resolution.DAILY).symbol # This dataset has multiple data columns. Create a subclass to set the default value column. class NasdaqCustomColumns(NasdaqDataLink): def __init__(self) -> None: # Select the column "mid". self.value_column_name = "mid"
Our Nasdaq Data Link integration supports any dataset from Nasdaq that has a URL starting with data.nasdaq.com/data/
. To import a dataset from Data Link, you need to get the dataset code. Follow these steps to get the dataset code:
- Open the Data Link catalog.
- (Optional) Use the filters on the left side bar to narrow down the catalog results.
- Click one of the data products.
- On the data product page, click one of the table names.
- In the top-right corner of the dataset page, copy the Nasdaq Data Link Code.
Data Summary
The data summary depends on the specific Data Link dataset you use. Follow these steps to view the data summary of a dataset:
- Open the Data Link catalog.
- Click one of the data products.
- On the data product page, click one of the table names.
- View the data frequency and description in the left sidebar.
- Above the chart, click
Table
to view the start date, end date, and data point attributes.
Backward Compatibility
QuantConnect/LEAN has supported Quandl since 2015. On January, 12, 2022, we moved the implementation from the LEAN GitHub repository to the Lean.DataSource.NasdaqDataLink GitHub repository. Through this transition, we maintained backward compatibility. All of the preceding code snippets work if you replace NasdaqDataLink
with Quandl
.
Example Applications
The Nasdaq Data Link sources allow you to explore different kinds of data in their database to develop trading strategies. Examples include the following strategies:
- Using alternative data to regress market regime/asset price.
- Backtesting exotic derivatives or private Equity investments.
For more example algorithms, see Examples.
Requesting Data
To add Data Link data to your algorithm, call the add_data
method. Save a reference to the dataset Symbol
so you can access the data later in your algorithm. If there is more than one value column in the Data Link dataset, to set the Value
property of the data objects, create a sublcass of the NasdaqDataLink
class and set its value_column_name
property to the column name.
class NasdaqDataLinkDataAlgorithm(QCAlgorithm): def initialize(self) -> None: self.set_start_date(2022, 1, 1) self.set_end_date(2022, 7, 1) self.set_cash(100000) # For premium datasets, provide your API Key # NasdaqDataLink.set_auth_code(self.get_parameter("nasdaq-data-link-api-key")) self.bitcoin_chain_symbol = self.add_data(NasdaqDataLink, "QDL/BCHAIN", Resolution.DAILY).symbol # This dataset has one data column ("Value") # Source : https://data.nasdaq.com/databases/BCHAIN self.bitfinex_exchange_rate_symbol = self.add_data(NasdaqCustomColumns, "QDL/BITFINEX", Resolution.DAILY).symbol # This dataset has multiple data columns # Source: https://data.nasdaq.com/databases/BITFINEX class NasdaqCustomColumns(NasdaqDataLink): def __init__(self) -> None: # Select the column "mid". self.value_column_name = "mid"
Accessing Data
To get the current Data Link data, index the current Slice
with the dataset Symbol
. Slice objects deliver unique events to your algorithm as they happen, but the Slice
may not contain data for your dataset at every time step. To avoid issues, check if the Slice
contains the data you want before you index it.
To get the default value of the dataset, use the value
property. To get the value of a specific column in the dataset, call the get_storage_dictionary
method and index the result with the column name.
def on_data(self, slice: Slice) -> None: point = slice.get(self.bitcoin_chain_symbol) if point: value = point.value self.log(f"{self.bitcoin_chain_symbol} at {slice.time}: {value}") point = slice.get(self.bitfinex_exchange_rate_symbol) if point: value = point.value storage_dictionary = point.get_storage_dictionary() volume = storage_dictionary["volume"] self.log(f"{self.bitfinex_exchange_rate_symbol} Bitfinex exchange rate at {slice.time}: {value}")
To iterate through all of the dataset objects in the current Slice
, call the get
method.
def on_data(self, slice: Slice) -> None: for dataset_symbol, data_point in slice.get(NasdaqDataLink).items(): self.log(f"{dataset_symbol} value at {slice.time}: {data_point.value}") for dataset_symbol, data_point in slice.get(NasdaqCustomColumns).items(): self.log(f"{dataset_symbol} value at {slice.time}: {data_point.value}")
Historical Data
The process to get historical Data Link data depends on your environment.
In Algorithms
To get historical Data Link data in an algorithm, call the history
method with the dataset Symbol
. If there is no data in the period you request, the history result is empty.
# DataFrames bitcoin_chain_df = self.history(self.bitcoin_chain_symbol, 100, Resolution.DAILY) bitfinex_exchange_rate_df = self.history(self.bitfinex_exchange_rate_symbol, 100, Resolution.DAILY) # Dataset objects bitcoin_chain_history = self.history[NasdaqDataLink](self.bitcoin_chain_symbol, 100, Resolution.DAILY) bitfinex_exchange_rate_history = self.history[NasdaqCustomColumns](self.bitfinex_exchange_rate_symbol, 100, Resolution.DAILY)
For more information about historical data, see History Requests.
In Research Notebooks
To get historical Data Link data in the Research Environment, call the download
method with the data URL.
from io import StringIO data = qb.download("https://data.nasdaq.com/api/v3/datatables/QDL/BCHAIN.csv?") df = pd.read_csv(StringIO(data), index_col=0)
To receive a notification when you can use the history
method in the Research Environment to get data from Data Link, subscribe to Lean.DataSource.NasdaqDataLink GitHub Issue #10.
Example Applications
The Nasdaq Data Link sources allow you to explore different kinds of data in their database to develop trading strategies. Examples include the following strategies:
- Using alternative data to regress market regime/asset price.
- Backtesting exotic derivatives or private Equity investments.
For more example algorithms, see Examples.