Dark Mode

Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Display candlestick charts right into your terminal.

License

Notifications You must be signed in to change notification settings

Julien-R44/cli-candlestick-chart

Folders and files

NameName
Last commit message
Last commit date

Latest commit

History

99 Commits

Repository files navigation



Draw candlesticks charts right into your terminal.



  • Features
  • API Usage
  • Binary Usage
  • Examples

Features

  • Customizable
  • Auto-fit to terminal size
  • Shipped as library with simple API
  • Shipped as binary for standalone usage

API Usage

Add this to your Cargo.toml

[dependencies]
cli-candlestick-chart = "0.3"
use cli_candlestick_chart::{Candle, Chart};

fn main() {
// Add some candles
let candles: Vec<Candle> = vec![
Candle::new(133.520004, 133.610001, 126.760002, 129.410004),
Candle::new(128.889999, 131.740005, 128.429993, 131.009995),
Candle::new(127.720001, 131.050003, 126.379997, 126.599998),
Candle::new(128.360001, 131.630005, 127.860001, 130.919998),
Candle::new(132.429993, 132.630005, 130.229996, 132.050003),
];

// Create and display the chart
let mut chart = Chart::new(&candles);

// Set the chart title
chart.set_name(String::from("BTC/USDT"));

// Set customs colors
chart.set_bear_color(1, 205, 254);
chart.set_bull_color(255, 107, 153);
chart.set_vol_bull_color(1, 205, 254);
chart.set_vol_bear_color(255, 107, 153);

chart.set_volume_pane_height(6);
chart.set_volume_pane_enabled(false);

chart.draw();
}

Binary Usage

Download the latest release for your platform here

USAGE:
cli-candlestick-chart.exe [OPTIONS] --mode

FLAGS:
-h, --help Prints help information
-V, --version Prints version information

OPTIONS:
--bear-color Sets the descending candles color in hexadecimal.
--bull-color Sets the ascending candles color in hexadecimal.
--chart-name Sets the chart name.
-f, --file [MODE:*-file] File to read candles from.`
-m, --mode Select the method for retrieving the candles.
[possible values: stdin, csv-file, json-file]

When requesting the CSV file mode, the library expects a CSV file with open,high,low,close headers fields.

When requesting the JSON or stdin mode, the library expects a JSON with the following format :

[
{
"open": 28994.009766,
"high": 29600.626953,
"low": 28803.585938,
"close": 29374.152344,
"volume": 13456 // Optional
},
...
]

Examples

API

Basic example with CSV parsing : Run with cargo run --example basic-with-csv-parsing --features=serde,csv

Fetch candles from binance : Run with cargo run --example fetch-from-binance --features=serde,reqwest

Binary

  • Read CSV from file :
./cli-candlestick-chart \
--mode=csv-file \
-f=./examples/BTC-USD.csv \
--chart-name="My BTC Chart" \
--bear-color="#b967ff" \
--bull-color="ff6b99"
  • Read from stdin :
echo '[
{
"open": 28994.009766,
"high": 29600.626953,
"low": 28803.585938,
"close": 29374.152344
},
{
"open": 29376.455078,
"high": 33155.117188,
"low": 29091.181641,
"close": 32127.267578
}
]' | ./cli-candlestick-chart \
--mode=stdin \
--chart-name="My BTC Chart" \
--bear-color="#b967ff" \
--bull-color="ff6b99"

Other versions

If you prefer Python, there is a port of the library, developed by BoboTiG, right there : https://github.com/BoboTiG/py-candlestick-chart

About

Display candlestick charts right into your terminal.

Topics

Resources

Readme

License

MIT license

Stars

Watchers

Forks

Sponsor this project

Packages

No packages published

Contributors 2

Languages