A lightweight health data analytics tool for monthly time-series visualization and distribution analysis.
Project description
๐ rr2graph โ Visualize Blood Pressure, Pulse, and Weight Data
rr2graph is a lightweight commandโline tool for processing and visualizing blood pressure, pulse, and weight data stored in Excel files.
It generates monthly plots (boxโswarm, scatter, histogram, violin) and exports them automatically as PNG, PDF, and SVG.
๐ค Example Output
Example visualization using scatter and boxโswarm plots:
Format: A4 Landscape (11.69 ร 8.27 inch)
The CLI prints all generated files:
Heart rows read: 81
Weight rows read: 49
โ Excel file: rr_data.xlsx
โ Months: 3
โ Output folder: plots/
Generating histogram plotsโฆ
Generated histogram plots stored at:
โ plots/png/(2026-02__2026-04 3 months) per month data and histogram.png
โ plots/pdf/(2026-02__2026-04 3 months) per month data and histogram.pdf
โ plots/svg/(2026-02__2026-04 3 months) per month data and histogram.svg
โฆ
๐ Quickstart (EndโUser)
The following steps show how to test rr2graph in a clean environment โ exactly as a new user would do.
-
Create a new working directory
mkdir rr2graph_test cd rr2graph_test
-
Create and activate a virtual environment
python3.11 -m venv venv source venv/bin/activate
-
Install from PyPI
pip install rr2graph
-
see the help information
rr2graph -h -
Verify the installation
rr2graph --info -
Generate test data
rr2graph -gThis creates a file:
test_rr_data.xlsx -
Generate example plots
rr2graph -e test_rr_data.xlsx -n 3
The generated plots will appear in the directory:
plots/
๐ Installation
-
Ensure you are in the project root
~/your/project/directory/
-
Install using Pipenv (editable mode)
pipenv install -e .
This installs:
- the rr2graph package (editable mode)
- all dependencies defined in pyproject.toml
-
Optional: Development dependencies
pipenv install -r requirements_dev.txt
๐งฐ CLI Usage
After installation, the command rr2graph becomes available.
Show help
rr2graph --help
usage: rr2graph [-h] [-e EXCEL] [-n NUM_OF_MONTHS] [-o OUTPUT] [-c CONFIG] [-v] [-g] [-i]
Reads Excel data and generates plots.
options:
-h, --help Show help and exit
-e, --excel EXCEL Path to Excel file (default: rr_data.xlsx)
-n, --num_of_months NUM_OF_MONTHS
Number of months 1โ6 (default: 3)
-o, --output OUTPUT Output folder for generated plots (default: plots/)
-c, --config CONFIG Optional YAML configuration file
-v, --version Show program version and exit
-g, --generate-test-data
Generate test_rr_data.xlsx and exit
-i, --info Show system and configuration information
๐งช Generate Test Data
rr2graph -g
Creates:
test_rr_data.xlsx
with realistic blood pressure, pulse, and weight data.
โน๏ธ System & Configuration Info
rr2graph --info
Example output:
rr2graph info
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
Version: 1.1.0
Python: 3.11.15
Installed at: /opt/homebrew/lib/python3.11/site-packages/rr2graph
Working dir: /Users/your_user/rr2graph_test
System: Darwin 25.3.0 (arm64)
Terminal: utf-8
No config file found (config.yaml missing).
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
Everything looks good โ
๐ Configuration File (YAML)
Example config.yaml:
excel: "rr_data.xlsx"
num_of_months: 3
output: "plots/"
| Field | Description |
|---|---|
| excel | Path to the Excel file containing RR data |
| num_of_months | Number of months to analyze |
| output | Output directory for PNG/PDF/SVG plots |
Use it via:
rr2graph -c config.yaml
๐ Output Structure
Running:
rr2graph -c config.yaml
produces:
plots/
โโโ png/
โโโ pdf/
โโโ svg/
๐ Project Structure
/your/project/directory/
.
โโโ config.yaml
โโโ examples/example_box_swarm.png
โโโ Pipfile
โโโ plots/
โย ย โโโ pdf/
โย ย โโโ png/
โย ย โโโ svg/
โย ย โโโ test/
โโโ pyproject.toml
โโโ README.md
โโโ requirements.txt
โโโ requirements_dev.txt
โโโ rr_data.xlsx
โโโ rr2graph/
โย ย โโโ cli.py
โย ย โโโ helpers.py
โย ย โโโ io.py
โย ย โโโ layout.py
โย ย โโโ monthly.py
โย ย โโโ orchestrator.py
โย ย โโโ tools/
โย ย โย ย โโโ bump_version.py
โย ย โโโ plots/
โย ย โโโ box_swarm.py
โย ย โโโ hist.py
โย ย โโโ scatter.py
โย ย โโโ violin.py
โโโ test_config.yaml
โโโ test_rr_data.xlsx
โโโ tests/
โโโ test_rr2graph.py
๐งช Run Tests
pipenv run pytest
๐ Troubleshooting
โ UnicodeDecodeError in YAML
You likely passed an Excel file as --config.
Correct:
rr2graph -c config.yaml
Incorrect:
rr2graph -c test_rr_data.xlsx
โ CLI command not found
Reinstall:
pipenv install -e .
๐จโ๐ป Developer Notes
Version bumping is handled via:
make version-patch
make version-minor
make version-major
TestPyPI upload:
make publish-test
Build artifacts:
make build
Manpage installation:
make install-man
make man
๐ License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file rr2graph-0.1.13.tar.gz.
File metadata
- Download URL: rr2graph-0.1.13.tar.gz
- Upload date:
- Size: 115.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7b3cce99158276cfb52c9345d76d055b8e0d0483d1931b35288fd373f568022a
|
|
| MD5 |
398770e58aa783a5f6129a9a5faa25ce
|
|
| BLAKE2b-256 |
cfed47fdf3b6c60ee639278e7c41f21bb29ccdd374c49dc7e1b95ed906ca02c9
|
File details
Details for the file rr2graph-0.1.13-py3-none-any.whl.
File metadata
- Download URL: rr2graph-0.1.13-py3-none-any.whl
- Upload date:
- Size: 16.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6604304a157fe61fda5f065ccc236f84f135e1b7438dce621b541d621df39ff9
|
|
| MD5 |
148d944c289c61aea12cbc9e564623c1
|
|
| BLAKE2b-256 |
5a83f5e6a1227ec269f2e949dc78e661480dc5343e969adaea81c58c892e2e13
|