Energy cost calculation
Project description
Energy cost
Python package to model your energy bill based on your energy consumption.
This energy bill is calculated based on a Contract or even a ContractHistory, which is a collection of contracts that can change over time.
A contract consists of 5 parts:
supplier: theTariffof your energy supplierdistributor: theTariffof your energy distributorfees: the government fees applicable to you, als defined as aTarifftaxes: the governmentTaxesapplicable to each cost component of your billtimezone: the timezone in which all calculations will be done
You can also specify a region, connection_type, customer_type and distributor_key in your contract, which will automatically fetch the applicable distributor tariffs, fees, taxes and timezone for you from our built in data. If your region is not yet supported, you can contribute the data for your region, see CONTRIBUTING.md for how to do that.
Contracts can be defined in a yaml file, which makes it easy to manage and update your contract over time. See notebooks/contract.ipynb for more info on how to define your contract in a yaml file.
We also have more detailed documentation on the different components of a contract, see notebooks for all available notebooks.
You can find example yaml files for tariffs and taxes in the examples directory.
A lot of tariffs are based on an Index, which is a price that changes over time based on the market price of energy, see notebooks/index.ipynb for more info.
Note on units: all consumption based costs are in €/MWh, all energy values are in MWh. All monetary values are in €.
Note on timezones: every method that takes timestamps as input also takes a timezone as input. All timestamps will be aligned to this timezone, and all outputs will be in this timezone as well. By default, the timezone is set by the regional data, but you can override it in your contract if needed.
Example usage
You can define your contract in a yaml file like this:
supplier:
- start: 2025-01-01T00:00:00+01:00
consumption:
constant_cost: 90.0
region: be_flanders
connection_type: electricity
customer_type: residential
distributor_key: fluvius_imewo
Then, you can use the Contract class to calculate your costs based on your consumption data:
from energy_cost import Contract, Meter
import pandas as pd
Contract.from_yaml("../examples/contracts/inline.yml")
consumption = Meter(
data=pd.DataFrame(
{
"timestamp": pd.date_range("2024-01-01T00:00:00+01:00", "2024-03-01T00:00:00+01:00", freq="15min"),
"value": 0.0002,
}
)
)
contract.apply([consumption])
For more detailed examples, see the notebooks in the notebooks directory.
Development
Prerequisites
- Python 3.12+
- uv (fast Python package manager)
1. Install dependencies
uv sync
uv tool install poethepoet
2. Notebooks
You can easilly test the project using our notebooks. They are located in the notebooks directory and can be run with:
poe notebooks
Some notebooks make use of external APIs and require API keys. You can set these in a .env file in the root of the project, using the .env.example file as a template.
If you add new features, please add a new notebook to demonstrate them.
3. Run tests
poe test
4. Code quality (pre-commit)
Pre-commit hooks are configured out of the box. Install them once:
pre-commit install
Every commit will automatically run:
| Tool | Task | Command |
|---|---|---|
| Ruff | Linting + auto-fix | poe lint |
| Ruff | Formatting | poe format |
| ty | Type checking | poe check |
You can also run them manually at any time.
Contributing
Contributions are welcome! See CONTRIBUTING.md for how to get started, including how to add support for new regions.
License
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 energy_cost-0.5.0.tar.gz.
File metadata
- Download URL: energy_cost-0.5.0.tar.gz
- Upload date:
- Size: 63.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
71b906afedee32d8b92b7685fe4f2c5c70eee6449f207af328b233017df15be9
|
|
| MD5 |
9fb2f0a626cf5a3b60c135dc7ef7b9a0
|
|
| BLAKE2b-256 |
06fe67c5a7cbf6aae8e0bc9841ac6b7a5efff4b1e9fe505e860c9f102f2dce69
|
File details
Details for the file energy_cost-0.5.0-py3-none-any.whl.
File metadata
- Download URL: energy_cost-0.5.0-py3-none-any.whl
- Upload date:
- Size: 59.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ffe8d847a58ea7f9ef43864644871eff973262469bf7d21e1fab1498fed71f40
|
|
| MD5 |
0c792174a0b1520d0f5e8276f4630566
|
|
| BLAKE2b-256 |
dd1868063ef1f031cf03eb23b0896b5200a81121a397a63ca60854fa77fb7d49
|