- Added the ChartAsync class, allowing for more sophisticated Charts and SubCharts. - Symbol searching, timeframe selectors, and more is now possible with this varation of Chart. `QtChart` and `WxChart` have access to all the methods that `ChartAsync` has, however they utilize their own respective event loops rather than asyncio. New Feature: `StreamlitChart` - Chart window that can display static data within a Streamlit application. Removed the `subscribe_click` method.
15 KiB
Docs
Common Methods
These methods can be used within the Chart, SubChart, ChartAsync, QtChart, WxChart and StreamlitChart objects.
set
data: pd.DataFrame
Sets the initial data for the chart.
The data must be given as a DataFrame, with the columns:
time | open | high | low | close | volume
The time column can also be named date, and the volume column can be omitted if volume is not enabled.
the `time` column must have rows all of the same timezone and locale. This is particularly noticeable for data which crosses over daylight saving hours on data with intervals of less than 1 day. Errors are likely to be raised if they are not converted beforehand.
update
series: pd.Series
Updates the chart data from a given bar.
The bar should contain values with labels of the same name as the columns required for using chart.set().
update_from_tick
series: pd.Series
Updates the chart from a tick.
The series should use the labels:
time | price | volume
As before, the time can also be named date, and the volume can be omitted if volume is not enabled.
The provided ticks do not need to be rounded to an interval (1 min, 5 min etc.), as the library handles this automatically.```````
create_line
color: str | width: int | -> Line
Creates and returns a Line object.
marker
time: datetime | position: 'above'/'below'/'inside' | shape: 'arrow_up'/'arrow_down'/'circle'/'square' | color: str | text: str | -> str
Adds a marker to the chart, and returns its id.
If the time parameter is not given, the marker will be placed at the latest bar.
remove_marker
marker_id: str
Removes the marker with the given id.
Usage:
marker = chart.marker(text='hello_world')
chart.remove_marker(marker)
horizontal_line
price: float/int | color: str | width: int | style: 'solid'/'dotted'/'dashed'/'large_dashed'/'sparse_dotted' | text: str | axis_label_visible: bool
Places a horizontal line at the given price.
remove_horizontal_line
price: float/int
Removes a horizontal line at the given price.
price_scale
mode: 'normal'/'logarithmic'/'percentage'/'index100' | align_labels: bool | border_visible: bool | border_color: str | text_color: str | entire_text_only: bool | ticks_visible: bool
Price scale options for the chart.
time_scale
right_offset: int | min_bar_spacing: float | visible: bool | time_visible: bool | seconds_visible: bool | border_visible: bool | border_color: str
Time scale options for the chart.
layout
background_color: str | text_color: str | font_size: int | font_family: str
Global layout options for the chart.
grid
vert_enabled: bool | horz_enabled: bool | color: str | style: 'solid'/'dotted'/'dashed'/'large_dashed'/'sparse_dotted'
Grid options for the chart.
candle_style
up_color: str | down_color: str | wick_enabled: bool | border_enabled: bool | border_up_color: str | border_down_color: str | wick_up_color: str | wick_down_color: str
Candle styling for each of the candle's parts (border, wick).
:class: note
Throughout the library, colors should be given as either:
* rgb: `rgb(100, 100, 100)`
* rgba: `rgba(100, 100, 100, 0.7)`
* hex: `#32a852`
volume_config
scale_margin_top: float | scale_margin_bottom: float | up_color: str | down_color: str
Volume config options.
The float values given to scale the margins must be greater than 0 and less than 1.
crosshair
mode | vert_width: int | vert_color: str | vert_style: str | vert_label_background_color: str | horz_width: int | horz_color: str | horz_style: str | horz_label_background_color: str
Crosshair formatting for its vertical and horizontal axes.
vert_style and horz_style should be given as one of: 'solid'/'dotted'/'dashed'/'large_dashed'/'sparse_dotted'
watermark
text: str | font_size: int | color: str
Overlays a watermark on top of the chart.
title
title: str
Sets the title label for the chart.
legend
visible: bool | ohlc: bool | percent: bool | color: str | font_size: int | font_family: str
Configures the legend of the chart.
create_subchart
volume_enabled: bool | position: 'left'/'right'/'top'/'bottom', width: float | height: float | sync: bool/str | -> SubChart
Creates and returns a SubChart object, placing it adjacent to the declaring Chart or SubChart.
position: specifies how the SubChart will float within the Chart window.
height | width: Specifies the size of the SubChart, where 1 is the width/height of the window (100%)
sync: If given as True, the SubChart's time scale will follow that of the declaring Chart or SubChart. If a str is passed, the SubChart will follow the panel with the given id. Chart ids can be accessed from thechart.id and subchart.id attributes.
`width` and `height` must be given as a number between 0 and 1.
Chart
volume_enabled: bool | width: int | height: int | x: int | y: int | on_top: bool | debug: bool
The main object used for the normal functionality of lightweight-charts-python, built on the pywebview library.
show
block: bool
Shows the chart window. If block is enabled, the method will block code execution until the window is closed.
hide
Hides the chart window, and can be later shown by calling chart.show().
exit
Exits and destroys the chart and window.
Line
The Line object represents a LineSeries object in Lightweight Charts and can be used to create indicators. As well as the methods described below, the Line object also has access to the title, marker and horizontal_line methods.
The `line` object should only be accessed from the [`create_line`](#create-line) method of `Chart`.
set
data: pd.DataFrame
Sets the data for the line.
This should be given as a DataFrame, with the columns: time | value
update
series: pd.Series
Updates the data for the line.
This should be given as a Series object, with labels akin to the line.set() function.
SubChart
The SubChart object allows for the use of multiple chart panels within the same Chart window. All of the Common Methods can be used within a SubChart. Its instance should be accessed using the create_subchart method.
SubCharts are arranged horizontally from left to right. When the available space is no longer sufficient, the subsequent SubChart will be positioned on a new row, starting from the left side.
Grid of 4 Example:
import pandas as pd
from lightweight_charts import Chart
if __name__ == '__main__':
chart = Chart(inner_width=0.5, inner_height=0.5)
chart2 = chart.create_subchart(position='right', width=0.5, height=0.5)
chart3 = chart2.create_subchart(position='left', width=0.5, height=0.5)
chart4 = chart3.create_subchart(position='right', width=0.5, height=0.5)
chart.watermark('1')
chart2.watermark('2')
chart3.watermark('3')
chart4.watermark('4')
df = pd.read_csv('ohlcv.csv')
chart.set(df)
chart2.set(df)
chart3.set(df)
chart4.set(df)
chart.show(block=True)
Synced Line Chart Example:
import pandas as pd
from lightweight_charts import Chart
if __name__ == '__main__':
chart = Chart(inner_width=1, inner_height=0.8)
chart2 = chart.create_subchart(width=1, height=0.2, sync=True, volume_enabled=False)
chart2.time_scale(visible=False)
df = pd.read_csv('ohlcv.csv')
df2 = pd.read_csv('rsi.csv')
chart.set(df)
line = chart2.create_line()
line.set(df2)
chart.show(block=True)
ChartAsync
api: object | top_bar: bool | search_box: bool
The ChartAsync object allows for asyncronous callbacks to be passed back to python, allowing for more sophisticated chart layouts including search boxes and timeframe selectors.
QtChart and WxChart also have access to the methods specific to ChartAsync, however they use their respective event loops to emit callbacks rather than asyncio.
api: The class object that the callbacks will be emitted to (see How to use Callbacks).top_bar: Adds a Top Bar to theChartorSubChartand allows use of thecreate_switchermethod.search_box: Adds a search box onto theChartorSubChartthat is activated by typing.
How to use Callbacks
Callbacks are emitted to the class given as the api parameter shown above.
Take a look at this minimal example:
class API:
def __init__(self):
self.chart = None
async def on_search(self, string):
print(f'You searched for {string}, within the chart holding the id: "{self.chart.id}"')
Upon searching in a Chart or SubChart window, the expected output would be akin to:
You searched for AAPL, within the chart holding the id: "window.blyjagcr"
When using SubChart's, the id will change depending upon which pane was used to search, due to the instance of self.chart dynamically updating to the latest pane which triggered the callback.
This allows access to the specific Common Methods for the pane in question.
Certain callback methods must be specifically named:
- Search callbacks will always be emitted to a method named
on_search
create_switcher
method: function | *options: str | default: str
method: The function from theapiclass given to the constructor that will receive the callback.options: The strings to be displayed within the switcher. This may be a variety of timeframes, security types, or whatever needs to be updated directly from the chart.default: The initial switcher option set.
Example:
import asyncio
import pandas as pd
from my_favorite_broker import get_bar_data
from lightweight_charts import ChartAsync
class API:
def __init__(self):
self.chart = None
self.symbol = 'TSLA'
self.timeframe = '5min'
async def on_search(self, searched_string): # Called when the user searches.
self.symbol = searched_string
new_data = await self.get_data()
if not new_data:
return
self.chart.set(new_data) # sets data for the Chart or SubChart in question.
self.chart.corner_text(searched_string)
async def on_timeframe(self, timeframe): # Called when the user changes the timeframe.
self.timeframe = timeframe
new_data = await self.get_data()
if not new_data:
return
self.chart.set(new_data)
async def get_data(self):
data = await get_bar_data(self.symbol, self.timeframe)
return data
async def main():
api = API()
chart = ChartAsync(api=api, debug=True)
chart.corner_text('TSLA')
chart.create_switcher(api.on_timeframe, '1min', '5min', '30min', 'H', 'D', 'W', default='5min')
df = pd.read_csv('ohlcv.csv')
chart.set(df)
await chart.show(block=True)
if __name__ == '__main__':
asyncio.run(main())
QtChart
widget: QWidget | volume_enabled: bool
The QtChart object allows the use of charts within a QMainWindow object, and has similar functionality to the Chart and ChartAsync objects for manipulating data, configuring and styling.
Callbacks can be recieved through the Qt event loop, using an API class that uses syncronous methods instead of asyncronous methods.
get_webview
-> QWebEngineView
Returns the QWebEngineView object.
Example:
import pandas as pd
from PyQt5.QtWidgets import QApplication, QMainWindow, QVBoxLayout, QWidget
from lightweight_charts.widgets import QtChart
app = QApplication([])
window = QMainWindow()
layout = QVBoxLayout()
widget = QWidget()
widget.setLayout(layout)
window.resize(800, 500)
layout.setContentsMargins(0, 0, 0, 0)
chart = QtChart(widget)
df = pd.read_csv('ohlcv.csv')
chart.set(df)
layout.addWidget(chart.get_webview())
window.setCentralWidget(widget)
window.show()
app.exec_()
WxChart
parent: wx.Panel | volume_enabled: bool
The WxChart object allows the use of charts within a wx.Frame object, and has similar functionality to the Chart and ChartAsync objects for manipulating data, configuring and styling.
Callbacks can be recieved through the Wx event loop, using an API class that uses syncronous methods instead of asyncronous methods.
get_webview
-> wx.html2.WebView
Returns a wx.html2.WebView object which can be used to for positioning and styling within wxPython.
Example:
import wx
import pandas as pd
from lightweight_charts.widgets import WxChart
class MyFrame(wx.Frame):
def __init__(self):
super().__init__(None)
self.SetSize(1000, 500)
panel = wx.Panel(self)
sizer = wx.BoxSizer(wx.VERTICAL)
panel.SetSizer(sizer)
chart = WxChart(panel)
df = pd.read_csv('ohlcv.csv')
chart.set(df)
sizer.Add(chart.get_webview(), 1, wx.EXPAND | wx.ALL)
sizer.Layout()
self.Show()
if __name__ == '__main__':
app = wx.App()
frame = MyFrame()
app.MainLoop()
StreamlitChart
parent: wx.Panel | volume_enabled: bool
The StreamlitChart object allows the use of charts within a Streamlit app, and has similar functionality to the Chart object for manipulating data, configuring and styling.
This object only supports the displaying of static data, and should not be used with the update_from_tick or update methods. Every call to the chart object must occur before calling load.
load
Loads the chart into the Streamlit app. This should be called after setting, styling, and configuring the chart, as no further calls to the StreamlitChart will be acknowledged.
Example:
import pandas as pd
from lightweight_charts.widgets import StreamlitChart
chart = StreamlitChart(width=900, height=600)
df = pd.read_csv('ohlcv.csv')
chart.set(df)
chart.load()