Skip to main content

Charting extension for CapInvest

Project description

CapInvest Charting extension

This extension provides a charting library for CapInvest Platform.

The library includes:

  • a charting infrastructure based on Plotly
  • a set of charting components
  • prebuilt charts for a set of commands that are built-in CapInvest extensions

[!NOTE] The charting library is an OBBject extension which means you'll have the functionality it exposes on every command result.

Installation

To install the extension, run the following command in this folder:

pip install capinvest-charting

PyWry dependency on Linux

The PyWry dependency handles the display of interactive charts and tables in a separate window. It is installed automatically with the CapInvest Charting extension.

When using Linux distributions, the PyWry dependency requires certain dependencies to be installed first.

  • Debian-based / Ubuntu / Mint: sudo apt install libwebkit2gtk-4.0-dev

  • Arch Linux / Manjaro: sudo pacman -S webkit2gtk

  • Fedora: sudo dnf install gtk3-devel webkit2gtk3-devel

Usage

To use the extension, run any of the CapInvest Platform endpoints with the chart argument set to True.

Here's an example of how it would look like in a python interface:

from capinvest import obb
equity_data = obb.equity.price.historical(symbol="TSLA", chart=True)

This results in a OBBject object containing a chart attribute, which contains Plotly JSON data.

In order to display the chart, you need to call the show() method:

equity_data.show()

Note: The show() method currently works either in a Jupyter Notebook or in a standalone python script with a PyWry based backend properly initialized.

Alternatively, you can use the fact that the capinvest-charting is an OBBject extension and use its available methods.

from capinvest import obb
res = obb.equity.price.historical("AAPL")
res.charting.show()

The above code will produce the same effect as the previous example.

Discovering available charts

Not all the endpoints are currently supported by the charting extension. To discover which endpoints are supported, you can run the following command:

from capinvest_charting import Charting
Charting.functions()

Using the to_chart method

The to_chart function should be taken as an advanced feature, as it requires the user to have a good understanding of the charting extension and the CapInvestFigure class.

The user can use any number of **kwargs that will be passed to the PlotlyTA class in order to build custom visualizations with custom indicators and similar.

Note that, this method will only work to some limited extent with data that is not standardized. Also, it is currently designed only to handle time series (OHLCV) data.

Example usage:

  • Plotting a time series with TA indicators

      from capinvest import obb
      res = obb.equity.price.historical("AAPL")
    
      indicators = dict(
          sma=dict(length=[20,30,50]),
          adx=dict(length=14),
          rsi=dict(length=14),
          macd=dict(fast=12, slow=26, signal=9),
          bbands=dict(length=20, std=2),
          stoch=dict(length=14),
          ema=dict(length=[20,30,50]),
      )
      res.charting.to_chart(**{"indicators": indicators})
    
  • Get all the available indicators

    # if you have a command result already
    res.charting.indicators
    
    # or if you want to know in standalone fashion
    from capinvest_charting import Charting
    Charting.indicators()
    

Add a visualization to an existing Platform command

To add a visualization to an existing command, you'll need to add a poetry plugin to your pyproject.toml file. The syntax should be the following:

[tool.poetry.plugins."capinvest_charting_extension"]
my_extension = "capinvest_my_extension.my_extension_views:MyExtensionViews"

Where the capinvest_charting_extension is mandatory, otherwise the charting extension won't be able to find the visualization.

And the suggested structure for the my_extension_views module is the following:

"""Views for MyExtension."""

from typing import Any, Dict, Tuple

from capinvest_charting.charts.price_historical import price_historical
from capinvest_charting.core.capinvest_figure import CapInvestFigure


class MyExtensionViews:
    """MyExtension Views."""

    @staticmethod
    def my_extension_price_historical(
        **kwargs,
    ) -> Tuple[CapInvestFigure, Dict[str, Any]]:
        """MyExtension Price Historical Chart."""
        return price_historical(**kwargs)

Note that my_extension_views lives under the capinvest_my_extension package.

Afterwards, you'll need to add the visualization to your new MyExtensionViews class. The convention to match the endpoint with the respective charting function is the following:

  • /equity/price/historical -> equity_price_historical
  • /technical/ema -> technical_ema
  • /my_extension/price_historical -> my_extension_price_historical

When you spot the charting function on the charting router file, you can add the visualization to it.

The implementation should leverage the already existing classes and methods to do so, namely:

  • CapInvestFigure
  • PlotlyTA

Note that the return of each charting function should respect the already defined return types: Tuple[CapInvestFigure, Dict[str, Any]].

The returned tuple contains a CapInvestFigure that is an interactive plotly figure which can be used in a Python interpreter, and a Dict[str, Any] that contains the raw data leveraged by the API.

After you're done implementing the charting function, you can use either the Python interface or the API to get the chart. To do so, you'll only need to set the already available chart argument to True. Or accessing the charting attribute of the OBBject object: my_obbject.charting.show().

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

capinvest_charting-1.0.8.tar.gz (3.6 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

capinvest_charting-1.0.8-py3-none-any.whl (3.6 MB view details)

Uploaded Python 3

File details

Details for the file capinvest_charting-1.0.8.tar.gz.

File metadata

  • Download URL: capinvest_charting-1.0.8.tar.gz
  • Upload date:
  • Size: 3.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.11.4 Windows/10

File hashes

Hashes for capinvest_charting-1.0.8.tar.gz
Algorithm Hash digest
SHA256 5c08988d3c2ff5daabe9bc42f850c9f1fc7736f732c6b988a82fbc9b5dde8e98
MD5 4b9540aa772c4b0b0f77c433aebd5b28
BLAKE2b-256 19f625594bb92244a86f1194f832352787a3aaad470072caf5159ea989538542

See more details on using hashes here.

File details

Details for the file capinvest_charting-1.0.8-py3-none-any.whl.

File metadata

File hashes

Hashes for capinvest_charting-1.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 1e37c8c5af2ba7ea7a6b983f285ad49c1a5a81017f062cff5de085a2d7a4c656
MD5 ca8ee95eaf3deabcd54ff767339fd2fd
BLAKE2b-256 255d21b3eeba7b008cc3f55b2078bb776cea0dd4d187241a110b150e7bfd7d7a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page