2019-05-20 11:26:45 +00:00
# Xiaomi Mi Scale
Code to read weight measurements from [Mi Body Composition Scale ](https://www.mi.com/global/mi-body-composition-scale/ ) (aka Xiaomi Mi Scale V2)
2019-09-02 04:12:33 +00:00

2019-05-20 11:26:45 +00:00
Note: Framework is present to also read from Xiaomi Scale V1, although I do not own one to test so code has not been maintained
2019-09-02 04:12:33 +00:00
## Getting the Mac Address of your Scale:
2019-05-20 11:48:32 +00:00
1. Retrieve the scale's MAC Address (you can identify your scale by looking for `MIBCS` entries) using this command:
```
$ sudo hcitool lescan
LE Scan ...
F8:04:33:AF:AB:A2 [TV] UE48JU6580
C4:D3:8C:12:4C:57 MIBCS
[...]
```
2019-09-02 04:12:33 +00:00
1. Note down your `MIBCS` mac address - we will need to use this as part of your configuration...
## Setup & Configuration:
### Running script with Docker:
2019-09-18 21:25:30 +00:00
1. Supported platforms:
1. linux/amd64
1. linux/arm64
1. linux/arm/v6
1. linux/arm/v7
2019-09-18 21:21:21 +00:00
1. Open `docker-compose.yml` (see below) and edit the environment to suit your configuration...
1. Stand up the container - `docker-compose up -d`
### docker-compose:
```
version: '3'
services:
mi-scale:
image: lolouk44/xiaomi-mi-scale:latest
container_name: mi-scale
restart: always
network_mode: host
privileged: true
environment:
MISCALE_MAC: 00:00:00:00:00:00 # Mac address of your scale
MQTT_HOST: 127.0.0.1 # MQTT Server (defaults to 127.0.0.1)
MQTT_PREFIX: miScale
# MQTT_USERNAME: # Username for MQTT server (comment out if not required)
# MQTT_PASSWORD: # Password for MQTT (comment out if not required)
# MQTT_PORT: # Defaults to 1883
# MQTT_TIMEOUT: 30 # Defaults to 60
# Auto-gender selection/config -- This is used to create the calculations such as BMI, Water/Bone Mass etc...
2019-09-18 21:34:46 +00:00
# Up to 3 users possible as long as weights do not overlap!
2019-09-18 21:21:21 +00:00
USER1_GT: 70 # If the weight is greater than this number, we'll assume that we're weighing User #1
USER1_SEX: male
USER1_NAME: Jo # Name of the user
USER1_HEIGHT: 175 # Height (in cm) of the user
2020-01-29 15:24:20 +00:00
USER1_DOB: 1990-01-01 # DOB (in yyyy-mm-dd format)
2019-09-18 21:21:21 +00:00
USER2_LT: 35 # If the weight is less than this number, we'll assume that we're weighing User #2
USER2_SEX: female
USER2_NAME: Serena # Name of the user
USER2_HEIGHT: 95 # Height (in cm) of the user
2020-01-29 15:24:20 +00:00
USER2_DOB: 1990-01-01 # DOB (in yyyy-mm-dd format)
2019-09-18 21:21:21 +00:00
USER3_SEX: female
USER3_NAME: Missy # Name of the user
USER3_HEIGHT: 150 # Height (in cm) of the user
2020-01-29 15:24:20 +00:00
USER3_DOB: 1990-01-01 # DOB (in yyyy-mm-dd format)
2019-09-18 21:21:21 +00:00
```
2019-09-02 04:12:33 +00:00
2019-09-18 21:25:30 +00:00
### Running script directly on your host system (if your platform is not listed/supported):
2019-09-02 04:12:33 +00:00
1. Install python requirements (pip3 install -r requirements.txt)
1. Open `wrapper.sh` and configure your environment variables to suit your setup.
1. Add a cron-tab entry to wrapper like so:
```sh
2020-01-29 15:24:20 +00:00
@reboot bash /path/to/wrapper.sh
2019-09-02 04:12:33 +00:00
```
2020-01-29 15:24:20 +00:00
**NOTE**: Althought once started the script runs continuously, it may take a few seconds for the data to be retrieved, computed and sent via mqtt.
2019-05-20 11:26:45 +00:00
2019-05-20 11:48:32 +00:00
## Home-Assistant Setup:
2019-09-02 04:12:33 +00:00
Under the `sensor` block, enter as many blocks as users configured in your environment variables:
```yaml
2019-05-20 11:48:32 +00:00
- platform: mqtt
2019-09-02 04:12:33 +00:00
name: "Example Name Weight"
2019-09-18 21:34:46 +00:00
state_topic: "miScale/USER_NAME/weight"
2019-05-20 11:48:32 +00:00
value_template: "{{ value_json['Weight'] }}"
unit_of_measurement: "kg"
2019-09-18 21:36:34 +00:00
json_attributes_topic: "miScale/USER_NAME/weight"
2019-05-20 11:48:32 +00:00
icon: mdi:scale-bathroom
- platform: mqtt
2019-09-02 04:12:33 +00:00
name: "Example Name BMI"
2019-09-18 21:34:46 +00:00
state_topic: "miScale/USER_NAME/weight"
2019-05-20 11:48:32 +00:00
value_template: "{{ value_json['BMI'] }}"
icon: mdi:human-pregnant
2019-09-02 04:12:33 +00:00
```


2019-05-20 11:48:32 +00:00
2019-05-20 11:26:45 +00:00
## Acknowledgements:
Thanks to @syssi (https://gist.github.com/syssi/4108a54877406dc231d95514e538bde9) and @prototux (https://github.com/wiecosystem/Bluetooth) for their initial code
2019-09-18 21:34:46 +00:00
2019-09-18 21:21:21 +00:00
Special thanks to @ned -kelly (https://github.com/ned-kelly) for his help turning a "simple" python script into a fully fledge docker container
2020-01-29 15:24:20 +00:00
## Updates log:
+ 2019-11-06
+ Initial Commit
+ 2020-01-28
+ Fixed issue with values in docker-compose seen as strings code (remove the `"` )
+ Fixed multi-arch platform builds
+ The script now runs continuously as opposed to once every 5 min, removed cron jobs
+ Fixed issue with string to int conversion (mqtt port, timeout) that used to break the paho-mqtt code
+ Updated the biometrics library with latest version from (https://github.com/wiecosystem/Bluetooth)
+ Added logging to docker console
+ Bumped paho-mqtt to V1.5.0
+ Bumped python to 3.8