Skip to main content

A maintained Python wrapper for TradingView's Lightweight Charts v5.x — featuring StreamChart, plugins, multi-pane layouts, and full IChartApi coverage.

Project description

python-lightweight-charts

PyPi Release Made with Python License Documentation

cover

A maintained Python wrapper for TradingView's Lightweight Charts v5.x.

Fork of louisnw01/lightweight-charts-python — original library by @louisnw01. This fork brings it up to Lightweight Charts v5, adds StreamChart, completes the IChartApi surface, and adds new plugins. Full credit and thanks to the original author.

Installation

pip install python-lightweight-charts

Features

  1. Streamlined for live data, with methods for updating directly from tick data.
  2. Multi-pane charts using Subcharts and a full pane-management API (add_pane, move_pane, resize_pane, remove_pane).
  3. The Toolbox — draw trendlines, rectangles, rays, and horizontal lines directly on charts.
  4. Events & Callbacks — timeframe selectors, search, hotkeys, and more.
  5. Tables for watchlists, order entry, and trade management.
  6. StreamChart — serve a chart over HTTP/WebSocket, viewable in any browser (no desktop window needed).
  7. Plugins: Tooltip, BandsIndicator, SessionHighlighting, HeatmapSeries, VolumeProfile, PositionTool.
  8. Full Lightweight Charts v5 IChartApi surface including price_scale, time_scale, watermark, grid, crosshair, and more.
  9. Direct integration of market data through Polygon.io's market data API.

Supports: Jupyter Notebooks, PyQt6, PyQt5, PySide6, wxPython, Streamlit, and asyncio.

PartTimeLarry: Interactive Brokers API and TradingView Charts in Python


1. Display data from a csv:

import pandas as pd
from lightweight_charts import Chart


if __name__ == '__main__':

    chart = Chart()

    # Columns: time | open | high | low | close | volume
    df = pd.read_csv('ohlcv.csv')
    chart.set(df)

    chart.show(block=True)

setting_data image


2. Updating bars in real-time:

import pandas as pd
from time import sleep
from lightweight_charts import Chart

if __name__ == '__main__':

    chart = Chart()

    df1 = pd.read_csv('ohlcv.csv')
    df2 = pd.read_csv('next_ohlcv.csv')

    chart.set(df1)

    chart.show()

    last_close = df1.iloc[-1]['close']

    for i, series in df2.iterrows():
        chart.update(series)

        if series['close'] > 20 and last_close < 20:
            chart.marker(text='The price crossed $20!')

        last_close = series['close']
        sleep(0.1)

live data gif


3. Updating bars from tick data in real-time:

import pandas as pd
from time import sleep
from lightweight_charts import Chart


if __name__ == '__main__':

    df1 = pd.read_csv('ohlc.csv')

    # Columns: time | price
    df2 = pd.read_csv('ticks.csv')

    chart = Chart()

    chart.set(df1)

    chart.show()

    for i, tick in df2.iterrows():
        chart.update_from_tick(tick)

        sleep(0.03)

tick data gif


4. Line Indicators:

import pandas as pd
from lightweight_charts import Chart


def calculate_sma(df, period: int = 50):
    return pd.DataFrame({
        'time': df['date'],
        f'SMA {period}': df['close'].rolling(window=period).mean()
    }).dropna()


if __name__ == '__main__':
    chart = Chart()
    chart.legend(visible=True)

    df = pd.read_csv('ohlcv.csv')
    chart.set(df)

    line = chart.create_line('SMA 50')
    sma_data = calculate_sma(df, period=50)
    line.set(sma_data)

    chart.show(block=True)

line indicators image


5. Styling:

import pandas as pd
from lightweight_charts import Chart


if __name__ == '__main__':

    chart = Chart()

    df = pd.read_csv('ohlcv.csv')

    chart.layout(background_color='#090008', text_color='#FFFFFF', font_size=16,
                 font_family='Helvetica')

    chart.candle_style(up_color='#00ff55', down_color='#ed4807',
                       border_up_color='#FFFFFF', border_down_color='#FFFFFF',
                       wick_up_color='#FFFFFF', wick_down_color='#FFFFFF')

    chart.volume_config(up_color='#00ff55', down_color='#ed4807')

    chart.watermark('1D', color='rgba(180, 180, 240, 0.7)')

    chart.crosshair(mode='normal', vert_color='#FFFFFF', vert_style='dotted',
                    horz_color='#FFFFFF', horz_style='dotted')

    chart.legend(visible=True, font_size=14)

    chart.set(df)

    chart.show(block=True)

styling image


6. Callbacks:

import pandas as pd
from lightweight_charts import Chart


def get_bar_data(symbol, timeframe):
    if symbol not in ('AAPL', 'GOOGL', 'TSLA'):
        print(f'No data for "{symbol}"')
        return pd.DataFrame()
    return pd.read_csv(f'bar_data/{symbol}_{timeframe}.csv')


def on_search(chart, searched_string):  # Called when the user searches.
    new_data = get_bar_data(searched_string, chart.topbar['timeframe'].value)
    if new_data.empty:
        return
    chart.topbar['symbol'].set(searched_string)
    chart.set(new_data)


def on_timeframe_selection(chart):  # Called when the user changes the timeframe.
    new_data = get_bar_data(chart.topbar['symbol'].value, chart.topbar['timeframe'].value)
    if new_data.empty:
        return
    chart.set(new_data, True)


def on_horizontal_line_move(chart, line):
    print(f'Horizontal line moved to: {line.price}')


if __name__ == '__main__':
    chart = Chart(toolbox=True)
    chart.legend(True)

    chart.events.search += on_search

    chart.topbar.textbox('symbol', 'TSLA')
    chart.topbar.switcher('timeframe', ('1min', '5min', '30min'), default='5min',
                          func=on_timeframe_selection)

    df = get_bar_data('TSLA', '5min')
    chart.set(df)

    chart.horizontal_line(200, func=on_horizontal_line_move)

    chart.show(block=True)

callbacks gif


7. StreamChart — browser-based chart over HTTP/WebSocket:

StreamChart spins up a local FastAPI/Uvicorn server and streams data to any browser tab. No desktop window is required — ideal for headless servers, notebooks, or remote development.

import pandas as pd
from lightweight_charts import StreamChart

if __name__ == '__main__':
    chart = StreamChart()

    df = pd.read_csv('ohlcv.csv')   # columns: time | open | high | low | close | volume
    chart.set(df)

    chart.show(port=8080, block=True)

Running the script prints a URL such as:

Chart server running at http://127.0.0.1:8080/?token=<64-hex-chars> — press Ctrl+C to stop

Open that URL in your browser to view the chart. The URL contains a one-time security token — keep it private.

Tip: pass open_browser=True to chart.show() to launch the browser automatically.


8. Plugins:

import pandas as pd
from lightweight_charts import Chart
from lightweight_charts.plugins import BandsIndicator, Tooltip

if __name__ == '__main__':
    chart = Chart()

    df = pd.read_csv('ohlcv.csv')
    chart.set(df)

    # Bollinger Bands
    upper = df['close'].rolling(20).mean() + 2 * df['close'].rolling(20).std()
    lower = df['close'].rolling(20).mean() - 2 * df['close'].rolling(20).std()
    bands = BandsIndicator(chart)
    bands.set(df['time'], upper, lower)

    # Hover tooltip
    tooltip = Tooltip(chart)

    chart.show(block=True)

Available plugins: Tooltip, BandsIndicator, SessionHighlighting, HeatmapSeries, VolumeProfile, PositionTool.

See the examples/ directory for a runnable script for each plugin.


Documentation

Maintained by Gopal Parashar · gopal.parashar421@gmail.com

This is a maintained fork of louisnw01/lightweight-charts-python by @louisnw01. Full credit to the original author.


This package is an independent creation and has not been endorsed, sponsored, or approved by TradingView. The author of this package does not have any official relationship with TradingView, and the package does not represent the views or opinions of TradingView.

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

python_lightweight_charts-1.0.0.tar.gz (201.1 kB view details)

Uploaded Source

Built Distribution

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

python_lightweight_charts-1.0.0-py3-none-any.whl (205.3 kB view details)

Uploaded Python 3

File details

Details for the file python_lightweight_charts-1.0.0.tar.gz.

File metadata

File hashes

Hashes for python_lightweight_charts-1.0.0.tar.gz
Algorithm Hash digest
SHA256 8a27c9353c4c954b657e6002ea994ed945eebc49a669a4bc1638ea8645f7aa8f
MD5 b32767e78ebad61f4624eb80e55e53a0
BLAKE2b-256 8553bb2235ecbb25e770f17f4b9b2b8de7992faf4ce29e0c1a59f1e675a1b613

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_lightweight_charts-1.0.0.tar.gz:

Publisher: publish.yml on gopalparashar421/lightweight-charts-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file python_lightweight_charts-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for python_lightweight_charts-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4d915856d6f226421073d350e82db4d0381604a03aaa3b662742faf65c19ee9f
MD5 2a32d24c568dc02d1232c6e6efffcb64
BLAKE2b-256 223fccd8154d99ea70c70b325f803330db30ea96a1642a3d0c90af6f7162aaff

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_lightweight_charts-1.0.0-py3-none-any.whl:

Publisher: publish.yml on gopalparashar421/lightweight-charts-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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