用python-miio控制电小酷智能排插CP5-PRO

本文详细介绍了如何通过米家IoT协议操控电小酷智能排插CP5-PRO,包括使用python-miio库、获取设备信息、重置网络、控制命令以及小米IoT协议文件的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

电小酷智能排插CP5-PRO

本文以电小酷智能排插CP5-PRO为例,并非广告,其它产品可参照。
产品主页: http://www.cucosmart.com/#/detail?detId=9

1. 米家的 IoT 协议

  • 功能划分为 service,每个 service 里面有若干 property 和若干 action。
  • 每个 service、property 和 action 都有 ID,分别是siidpiidaiid
  • 米家设备的控制就是通过小米IoT协议访问、修改这些property,调用action。

2. 开源项目 python-miio

  • python-miio提供了访问小米 IoT 设备的 Python 接口,并提供了命令行工具miiocli
  • 项目地址:https://github.com/rytilahti/python-miio.git
  • 安装:pip install python-miio
    • 2023年8月:新命令 genericmiot还未发布,使用下面的命令安装最新代码:
      pip install git+https://github.com/rytilahti/python-miio.git

3. 设备的IP地址和设备TOKEN

  • 访问设备需要设备的token
  • 支持 WiFi 访问的米家 IoT 设备在其 IP地址的54321端口监听UDP消息
  • 运行miiocli genericmiot命令需要获取设备的IP地址和设备token
  • 重置设备的网络信息,设备token会更新
如何重置设备
  1. 安装米家App并登录米家账号
  2. 长按总电源键5秒,重置设备网络配置
  3. 在米家App中添加设备:发现设备后选择它,按照提示输入WiFi名称和密码
查看设备的IP地址和设备token
  • 网上有各种方法,大概是3种思路:
    • 获取米家App本地的database(本文写于2023年9月:成功)
    • 利用bug,获取泄露的信息(本文写于2023年9月:不成功)
    • 利用其它插件或者与米家合作的App获取(未尝试)
    • 利用米家账号和密码从后台获取(本文写于2023年9月:成功)
  • 目前有效的最简单的方法是:利用米家账号从后台获取

4. 设备的小米IoT协议描述文件

5. 控制命令

# 关闭插座-1
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 3, 'value': False}]"
# 关闭插座-2
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 4, 'value': False}]"
# 关闭插座-3
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 5, 'value': False}]"
# 关闭插座-4
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 6, 'value': False}]"
# 关闭USB插口
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 7, 'value': False}]"
# 打开插座-1
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 3, 'value': False}]"
# 打开插座-2
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 4, 'value': True}]"
# 打开插座-3
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 5, 'value': True}]"
# 打开插座-4
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 6, 'value': True}]"
# 打开USB插口
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command set_properties "[{'did': 'switchon', 'piid': 1, 'siid': 7, 'value': True}]"

# 也可以调用Action,但是只提供了toggle命令
# 所以还要先get属性才知道toggle前后的状态
miiocli genericmiot --ip 192.168.xx.xxx --token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx raw_command action "{'aiid': 1, 'did': 'call-2-1', 'in': [], 'siid': 7}"
### 如何使用 Python `miio` 库通过 IP 和 Token 控制小米智能家居设备 要实现对小米智能家居设备的控制,可以按照以下方法操作: #### 准备工作 确保已安装 `python-miio` 库。如果尚未安装,可以通过 pip 安装: ```bash pip install python-miio ``` #### 使用 IP 和 Token 进行连接 以下是基于 IP 地址和 Token 的基本代码框架,用于初始化并发送命令到指定的小米设备。 ```python from miio import Device ip_address = "192.168.x.x" # 替换为实际设备的IP地址 token = "00000000000000000000000000000000" # 替换为实际设备的Token # 初始化Device对象 device = Device(ip=ip_address, token=token) # 发送自定义命令 (以获取设备状态为例) response = device.send("get_prop", ["status"]) print(f"设备状态: {response}") ``` 上述代码中的 `send()` 方法允许向设备发送任意指令。具体可用的属性 (`prop`) 或者可执行的方法取决于目标设备的支持情况[^1]。 #### 处理 Token 获取失败的情况 对于某些设备,在配置 WiFi 后可能无法正常通过工具(如 `mirobo discover`)获得有效的 Token,通常会返回 `'ffffffffffffffffffff'` 或 `'0000000000000000'` 类似的占位符值[^2]。此时建议尝试以下方式解决: - **手动提取 Token**:从手机 App 数据包中抓取 Xiaomi Mi Home 的通信数据流,找到对应的 Token。 - **重置设备**:将设备恢复出厂设置后重新配网,并尽快捕获新的 Token。 #### 配合特定型号的功能调用 针对不同类型的设备,需查阅其官方文档或第三方解析资料了解支持的具体接口参数。例如,对于智能排插 CP5-Pro 可参考 Miot 协议说明页面提供的字段详情[^3]。 --- ### 示例应用 - 开启/关闭智能插座 下面展示了一个简单的例子,演示如何利用前述逻辑开关一个兼容的智能插座。 ```python from miio import ChuangMiPlug plug_ip = "192.168.y.y" plug_token = "abcdefg..." smart_plug = ChuangMiPlug(plug_ip, plug_token) if smart_plug.status().is_on: result = smart_plug.off() else: result = smart_plug.on() print(result) ``` 此脚本先判断当前源状态再决定执行开启还是关闭动作;最后打印出操作的结果反馈信息。 ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值