
Security News
Deno 2.6 + Socket: Supply Chain Defense In Your CLI
Deno 2.6 introduces deno audit with a new --socket flag that plugs directly into Socket to bring supply chain security checks into the Deno CLI.
pycharting
Advanced tools
High-performance financial charting library for OHLC data visualization with technical indicators
High‑performance financial charting library for OHLC data visualization with technical indicators.
PyCharting lets you render large OHLC time series (hundreds of thousands to millions of candles) in the browser with a single Python call.
It runs a lightweight FastAPI server locally, streams your data to a uPlot-based frontend, and gives you an interactive viewport with overlays and indicator subplots.

plot(...), plus helpers to manage the server.Install the latest released version from PyPI:
pip install pycharting
This will install the pycharting package along with its runtime dependencies (numpy, pandas, fastapi, uvicorn, and friends).
If you want to develop or run against main:
git clone https://github.com/alihaskar/pycharting.git
cd pycharting
pip install -e .
If you use Poetry instead of pip:
git clone https://github.com/alihaskar/pycharting.git
cd pycharting
poetry install
The primary API is a single plot function that takes OHLC arrays (plus optional overlays and subplots), starts a local server, and opens your default browser on the interactive chart.
You normally import everything you need like this:
from pycharting import plot, stop_server, get_server_status
When you run this script, PyCharting will:
Once you have your OHLC series, you pass additional series to plot in two different ways:
overlays = {
"SMA_50": sma(close, 50), # rendered on top of price
"EMA_200": ema(close, 200),
}
subplots = {
"RSI_like": rsi_like_series, # rendered in its own panel below price
"Stoch_like": stoch_series,
}
plot(
index,
open_,
high,
low,
close,
overlays=overlays,
subplots=subplots,
)
See demo.py for a full example that generates synthetic data and wires up both overlays and indicator-style subplots.
Run the demo from the project root:
python demo.py
You should see something similar to the screenshot above: a price panel with overlays, plus RSI-like and stochastic-like subplots underneath.
The public API is intentionally small and focused. All functions are available from the top-level pycharting package.
plotfrom typing import Dict, Any, Optional, Union
import numpy as np
import pandas as pd
from pycharting import plot
ArrayLike = Union[np.ndarray, pd.Series, list]
result: Dict[str, Any] = plot(
index: ArrayLike,
open: ArrayLike,
high: ArrayLike,
low: ArrayLike,
close: ArrayLike,
overlays: Optional[Dict[str, ArrayLike]] = None,
subplots: Optional[Dict[str, ArrayLike]] = None,
session_id: str = "default",
port: Optional[int] = None,
open_browser: bool = True,
server_timeout: float = 2.0,
)
close), rendered on the main price chart.None, PyCharting picks an available port.False, you get the URL back in result["url"] but the browser is not opened automatically.The returned dict includes:
status: "success" or "error",url: full chart URL (including session query),server_url: base FastAPI server URL,session_id: the session identifier you passed in,data_points: number of OHLC rows,server_running: boolean.stop_serverfrom pycharting import stop_server
stop_server()
Stops the active chart server if it is running. This is useful in long‑running processes and demos to clean up after you are done exploring charts.
get_server_statusfrom pycharting import get_server_status
status = get_server_status()
print(status)
Returns a small dict with:
running: whether the server is alive,server_info: host/port and other metadata if running,active_sessions: number of registered data sessions.The library follows a modern src/ layout:
pycharting/
├── src/
│ ├── core/ # Chart server lifecycle and internals
│ ├── data/ # Data ingestion, validation, and slicing
│ ├── api/ # FastAPI routes and Python API surface
│ └── web/ # Static frontend (HTML + JS for charts)
├── tests/ # Test suite
├── data/ # Sample CSVs and fixtures
└── pyproject.toml # Project configuration
Contributions, bug reports, and feature suggestions are welcome. Please open an issue or pull request on GitHub.
Basic workflow:
git checkout -b feature/my-feature.main.PyCharting is licensed under the MIT License.
https://pypi.org/project/pycharting/https://github.com/alihaskar/pychartinghttps://github.com/alihaskar/pycharting/issuesFAQs
High-performance financial charting library for OHLC data visualization with technical indicators
We found that pycharting demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Deno 2.6 introduces deno audit with a new --socket flag that plugs directly into Socket to bring supply chain security checks into the Deno CLI.

Security News
New DoS and source code exposure bugs in React Server Components and Next.js: what’s affected and how to update safely.

Security News
Socket CEO Feross Aboukhadijeh joins Software Engineering Daily to discuss modern software supply chain attacks and rising AI-driven security risks.