Battery Consumption custom component for Home Assistant.
This component is used to compute statistics on a battery (based on its level state)
This component allows to display :
- the current varation of battery
- the charge in % or in Wh/kWh...
- the discharge in % or in Wh/kWh ...
- the total charge/discharge
The refresh rate is based on battery's level state
Either use HACS (default), either manual
HACS (Home Assistant Community Store)
- Go to HACS page on your Home Assistant instance
- Select
integration
- Press add icon and search for
battery_consumption
- Select battery_consumption and install
Manual Procedure
- Download the folder battery_consumption from the latest release (with right click, save link as)
- Place the downloaded directory on your Home Assistant machine in the
config/custom_components
folder (when there is nocustom_components
folder in the folder where yourconfiguration.yaml
file is, create it and place the directory there) - restart HomeAssistant
None
in configuration.yaml, declare :
##configuration.yaml example
battery_consumption:
zoe:
source: sensor.battery_level
# attribute : attribute of source to monitor
# unique_id : to set a unique id to this sensor
# precision : the precision of state
unit_of_measurement: kWh
battery_capacity: 41
galaxy_s7:
source: sensor.sm_g930f_niveau_de_batterie
unit_of_measurement: Wh
battery_capacity: 11.55
where :
- source is name of the state to monitor
- attribute is the attribute of source to monitor
- unique_id is to set a unique id to this sensor
- precision is the precision you set (default 2)
- battery_capacity is the capacity of the monitored battery
- unit_of_measurement is the unit of capacity : kWh, Wh, ...
Only source item is required
For each battery to monitor one sensor is created.
sensor name | support | unit | Description |
---|---|---|---|
battery_consumption+name of sensor to monitor | V1.0.0 | % | the current value of battery to monitor |
The sensor is created with the following attribute :
Attribute name | support | present | unit | Description |
---|---|---|---|---|
Source | V1.0.0 | always | string | the name of battery to monitor |
Previous value | V1.0.0 | always | % | the previous value of battery to monitor |
Variation | V1.0.0 | always | % | the difference between current and previous value |
Battery charge | V1.0.0 | always | % | the difference between current and previous value if positive (battery is charging) |
Battery discharge | V1.0.0 | always | % | the difference between current and previous value if negative (battery is discharging) |
Total charge | V1.0.0 | always | % | the sum of all battery charge since the beginning |
Total discharge | V1.0.0 | always | % | the sum of all battery discharge since the beginning |
Capacity | V1.0.0 | if capacity given | kWh , Wh, ... | the capacity of the battery cf. yaml |
Capacity unit | V1.0.0 | if capacity given | kWh , Wh, ... | the unif of the capacity of the battery cf. yaml |
Energy charge | V1.0.0 | if capacity given | kWh , Wh, ... | the battery charge converted in energy |
Energy discharge | V1.0.0 | if capacity given | kWh , Wh, ... | the battery discharge converted in energy |
Total energy charge | V1.0.0 | if capacity given | kWh , Wh, ... | the total battery charge converted in energy |
Total energy discharge | V1.0.0 | if capacity given | kWh , Wh, ... | the total battery discharge converted in energy |
Typical use is to follow the consumption of battery thanks to utility meter
##configuration.yaml example
template:
- sensor:
- name: zoe_batterie_total_charge
state: "{{ state_attr('sensor.battery_consumption_sensor_battery_level', 'total_energy_charge') }}"
unit_of_measurement: 'kWh'
device_class: energy
state_class: total
- sensor:
- name: zoe_batterie_total_discharge
state: "{{ state_attr('sensor.battery_consumption_sensor_battery_level', 'total_energy_discharge') }}"
unit_of_measurement: 'kWh'
device_class: energy
state_class: total
## UTILITY METER
utility_meter:
zoe_batterie_total_charge_daily:
source: sensor.zoe_batterie_total_charge
cycle : daily
zoe_batterie_total_charge_weekly:
source: sensor.zoe_batterie_total_charge
cycle : weekly
zoe_batterie_total_charge_monthly:
source: sensor.zoe_batterie_total_charge
cycle : monthly
zoe_batterie_total_discharge_daily:
source: sensor.zoe_batterie_total_discharge
cycle : daily
zoe_batterie_total_discharge_weekly:
source: sensor.zoe_batterie_total_discharge
cycle : weekly
zoe_batterie_total_discharge_monthly:
source: sensor.zoe_batterie_total_discharge
cycle : monthly
Another typical use is to follow the variation of battery in statistics graph .
##configuration.yaml example
template:
- sensor:
- name: zoe_batterie_variation
state: "{{ state_attr('sensor.battery_consumption_sensor_battery_level', 'variation') }}"
unit_of_measurement: '%'
device_class: battery
state_class: measurement