Skip to main content

Python library for interfacing with Xiaomi smart appliances

Project description

Chat PyPI version Build Status Coverage Status Documentation status Black Hound

This library (and its accompanying cli tool) can be used to interface with devices using Xiaomi’s miIO and miOT protocols.

Getting started

If you already have a token for your device and the device type, you can directly start using miiocli tool. If you don’t have a token for your device, refer to Getting started section of the manual for instructions how to obtain it.

The miiocli is the main way to execute commands from command line. You can always use –help to get more information about the available commands. For example, executing it without any extra arguments will print out options and available commands:

$ miiocli --help
Usage: miiocli [OPTIONS] COMMAND [ARGS]...

Options:
  -d, --debug
  -o, --output [default|json|json_pretty]
  --help                          Show this message and exit.

Commands:
  airconditioningcompanion
  ..

You can get some information from any miIO/miOT device, including its device model, using the info command:

miiocli device --ip <ip> --token <token> info

Model: some.device.model1
Hardware version: esp8285
Firmware version: 1.0.1_0012
Network: {'localIp': '<ip>', 'mask': '255.255.255.0', 'gw': '<ip>'}
AP: {'rssi': -73, 'ssid': '<nnetwork>', 'primary': 11, 'bssid': '<bssid>'}

Each different device type is supported by their corresponding module (e.g., vacuum or fan). You can get the list of available commands for any given module by passing –help argument to it:

$ miiocli vacuum --help

Usage: miiocli vacuum [OPTIONS] COMMAND [ARGS]...

Options:
  --ip TEXT       [required]
  --token TEXT    [required]
  --id-file FILE
  --help          Show this message and exit.

Commands:
  add_timer                Add a timer.
  ..

API usage

All functionality is accessible through the miio module:

from miio import Vacuum

vac = Vacuum("<ip address>", "<token>")
vac.start()

Each separate device type inherits from miio.Device (and in case of miOT devices, miio.MiotDevice) which provides common API.

Please refer to API documentation for more information.

Troubleshooting

You can find some solutions for the most common problems can be found in Troubleshooting section.

If you have any questions, or simply want to join up for a chat, check our Matrix room.

Contributing

We welcome all sorts of contributions from patches to add improvements or fixing bugs to improving the documentation. To ease the process of setting up a development environment we have prepared a short guide for getting you started.

Supported devices

  • Xiaomi Mi Robot Vacuum V1, S5, M1S

  • Xiaomi Mi Home Air Conditioner Companion

  • Xiaomi Mi Smart Air Conditioner A (xiaomi.aircondition.mc1, mc2, mc4, mc5)

  • Xiaomi Mi Air Purifier 2, 3H, 3C, Pro (zhimi.airpurifier.m2, mb3, mb4, v7)

  • Xiaomi Mi Air (Purifier) Dog X3, X5, X7SM (airdog.airpurifier.x3, airdog.airpurifier.x5, airdog.airpurifier.x7sm)

  • Xiaomi Mi Air Humidifier

  • Xiaomi Aqara Camera

  • Xiaomi Aqara Gateway (basic implementation, alarm, lights)

  • Xiaomi Mijia 360 1080p

  • Xiaomi Mijia STYJ02YM (Viomi)

  • Xiaomi Mijia 1C STYTJ01ZHM (Dreame)

  • Xiaomi Mi Smart WiFi Socket

  • Xiaomi Chuangmi Plug V1 (1 Socket, 1 USB Port)

  • Xiaomi Chuangmi Plug V3 (1 Socket, 2 USB Ports)

  • Xiaomi Smart Power Strip V1 and V2 (WiFi, 6 Ports)

  • Xiaomi Philips Eyecare Smart Lamp 2

  • Xiaomi Philips RW Read (philips.light.rwread)

  • Xiaomi Philips LED Ceiling Lamp

  • Xiaomi Philips LED Ball Lamp (philips.light.bulb)

  • Xiaomi Philips LED Ball Lamp White (philips.light.hbulb)

  • Xiaomi Philips Zhirui Smart LED Bulb E14 Candle Lamp

  • Xiaomi Philips Zhirui Bedroom Smart Lamp

  • Huayi Huizuo Lamps

  • Xiaomi Universal IR Remote Controller (Chuangmi IR)

  • Xiaomi Mi Smart Pedestal Fan V2, V3, SA1, ZA1, ZA3, ZA4, P5, P9, P10, P11

  • Xiaomi Rosou SS4 Ventilator (leshow.fan.ss4)

  • Xiaomi Mi Air Humidifier V1, CA1, CA4, CB1, MJJSQ, JSQ, JSQ1, JSQ001

  • Xiaomi Mi Water Purifier (Basic support: Turn on & off)

  • Xiaomi Mi Water Purifier D1, C1 (Triple Setting)

  • Xiaomi PM2.5 Air Quality Monitor V1, B1, S1

  • Xiaomi Smart WiFi Speaker

  • Xiaomi Mi WiFi Repeater 2

  • Xiaomi Mi Smart Rice Cooker

  • Xiaomi Smartmi Fresh Air System VA2 (zhimi.airfresh.va2), VA4 (zhimi.airfresh.va4), A1 (dmaker.airfresh.a1), T2017 (dmaker.airfresh.t2017)

  • Yeelight lights (basic support, we recommend using python-yeelight)

  • Xiaomi Mi Air Dehumidifier

  • Xiaomi Tinymu Smart Toilet Cover

  • Xiaomi 16 Relays Module

  • Xiaomi Xiao AI Smart Alarm Clock

  • Smartmi Radiant Heater Smart Version (ZA1 version)

  • Xiaomi Mi Smart Space Heater

  • Xiaomiyoupin Curtain Controller (Wi-Fi) (lumi.curtain.hagl05)

  • Xiaomi Xiaomi Mi Smart Space Heater S (zhimi.heater.mc2)

  • Yeelight Dual Control Module (yeelink.switch.sw1)

  • Scishare coffee maker (scishare.coffee.s1102)

  • Qingping Air Monitor Lite (cgllc.airm.cgdn1)

Feel free to create a pull request to add support for new devices as well as additional features for supported devices.

Home Assistant support

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python-miio-0.5.5.tar.gz (194.4 kB view details)

Uploaded Source

Built Distribution

python_miio-0.5.5-py3-none-any.whl (265.9 kB view details)

Uploaded Python 3

File details

Details for the file python-miio-0.5.5.tar.gz.

File metadata

  • Download URL: python-miio-0.5.5.tar.gz
  • Upload date:
  • Size: 194.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.1 Linux/5.10.16-arch1-1

File hashes

Hashes for python-miio-0.5.5.tar.gz
Algorithm Hash digest
SHA256 d81b6f35d8232bec26e0371c81706718877a94d2de5ef51487f5fd7f8fde7319
MD5 a4be27cb1c23b1efcadaa114f63822f3
BLAKE2b-256 192b9ca2e4372e4baddaa402b9a00d2b51031b2d6bd31d682fc910ddec513f07

See more details on using hashes here.

File details

Details for the file python_miio-0.5.5-py3-none-any.whl.

File metadata

  • Download URL: python_miio-0.5.5-py3-none-any.whl
  • Upload date:
  • Size: 265.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.1 Linux/5.10.16-arch1-1

File hashes

Hashes for python_miio-0.5.5-py3-none-any.whl
Algorithm Hash digest
SHA256 08399b8b15dfb8b83cb0c1d2282e88f0bf0345ebd55d641eabfaae1f88475fd2
MD5 edf7c411738b0501d231835c0bed291e
BLAKE2b-256 bb73a3880f842f186557d68c4cac0fe92523409b5ae191b05b87745c9258c92a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page