English
Languages
English
Japanese
German
Korean
Portuguese, Brazilian
French
Shortcuts

Source code for qiskit.finance.data_providers.exchange_data_provider

# This code is part of Qiskit.
#
# (C) Copyright IBM 2019, 2020.
#
# This code is licensed under the Apache License, Version 2.0. You may
# obtain a copy of this license in the LICENSE.txt file in the root directory
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
#
# Any modifications or derivative works of this code must retain this
# copyright notice, and modified files need to carry a notice indicating
# that they have been altered from the originals.

""" Exchange data provider. """

from typing import Union, List
import datetime
import logging

from qiskit.aqua import MissingOptionalLibraryError
from ._base_data_provider import BaseDataProvider, StockMarket
from ..exceptions import QiskitFinanceError

try:
    import quandl
    _HAS_QUANDL = True
except ImportError:
    _HAS_QUANDL = False

logger = logging.getLogger(__name__)


[docs]class ExchangeDataProvider(BaseDataProvider): """Exchange data provider. Please see: https://github.com/Qiskit/qiskit-tutorials/blob/master/legacy_tutorials/aqua/finance/data_providers/time_series.ipynb for instructions on use, which involve obtaining a Quandl access token. """
[docs] def __init__(self, token: str, tickers: Union[str, List[str]], stockmarket: StockMarket = StockMarket.LONDON, start: datetime.datetime = datetime.datetime(2016, 1, 1), end: datetime.datetime = datetime.datetime(2016, 1, 30)) -> None: """ Initializer Args: token: quandl access token tickers: tickers stockmarket: LONDON, EURONEXT, or SINGAPORE start: first data point end: last data point precedes this date Raises: MissingOptionalLibraryError: Quandl not installed QiskitFinanceError: provider doesn't support given stock market """ super().__init__() if not _HAS_QUANDL: raise MissingOptionalLibraryError( libname='Quandl', name='ExchangeDataProvider', pip_install='pip install quandl') self._tickers = [] # type: Union[str, List[str]] if isinstance(tickers, list): self._tickers = tickers else: self._tickers = tickers.replace('\n', ';').split(";") self._n = len(self._tickers) if stockmarket not in [StockMarket.LONDON, StockMarket.EURONEXT, StockMarket.SINGAPORE]: msg = "ExchangeDataProvider does not support " msg += stockmarket.value msg += " as a stock market." raise QiskitFinanceError(msg) # This is to aid serialization; string is ok to serialize self._stockmarket = str(stockmarket.value) self._token = token self._tickers = tickers self._start = start.strftime('%Y-%m-%d') self._end = end.strftime('%Y-%m-%d')
[docs] def run(self) -> None: """ Loads data, thus enabling get_similarity_matrix and get_covariance_matrix methods in the base class. """ quandl.ApiConfig.api_key = self._token quandl.ApiConfig.api_version = '2015-04-09' self._data = [] stocks_notfound = [] stocks_forbidden = [] for _, ticker_name in enumerate(self._tickers): stock_data = None name = self._stockmarket + "/" + ticker_name try: stock_data = quandl.get(name, start_date=self._start, end_date=self._end) except quandl.AuthenticationError as ex: raise QiskitFinanceError("Quandl invalid token.") from ex except quandl.NotFoundError as ex: stocks_notfound.append(name) continue except quandl.ForbiddenError as ex: stocks_forbidden.append(name) continue except quandl.QuandlError as ex: raise QiskitFinanceError("Quandl Error for '{}'.".format(name)) from ex try: self._data.append(stock_data["Close"]) except KeyError as ex: raise QiskitFinanceError("Cannot parse Quandl '{}'output.".format(name)) from ex if stocks_notfound or stocks_forbidden: err_msg = 'Stocks not found: {}. '.format(stocks_notfound) if stocks_notfound else '' if stocks_forbidden: err_msg += 'You do not have permission to view this data. ' \ 'Please subscribe to this database: {}'.format(stocks_forbidden) raise QiskitFinanceError(err_msg)

© Copyright 2020, Qiskit Development Team. Last updated on 2021/05/25.

Built with Sphinx using a theme provided by Read the Docs.