如何通过Python语言对接语音播报盒

如何通过Python语言对接语音播报盒呢?

本文描述了使用Python语言调用HTTP接口,对接语音播报盒,。

可选用产品:可根据实际场景需求,选择对应的规格
序号 设备名称 厂商
1 智能语音喇叭3 友友物联
2 智能语音音柱|10W

下面以每款产品为例,用Python-http.client编程对接语音播报盒:

1. 智能语音喇叭3

如何通过Python语言对接语音播报盒_第1张图片

远程语音播报、语音提醒、语音通知、语音警报;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒等;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
双发声单元、音量大;
支持远程音量、音色、语调、语速设置;
支持多音字、支持数字(数值、金额、手机号等)读法;
内置铃声、提示音、警示音各5种;
可远程控制环状LED灯带颜色,同时实现视觉提醒;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;
即插即用,无需安装、走线;

更多...


使用Python语言调用HTTP接口控制智能语音喇叭3的代码
以设备控制(向设备下发命令)为例

全部接口文档复制

# 核心请求地址:https://api.yoyoiot.cn/拼接你的AppID的值/device/control/?sign=拼接你计算得到的签名&拼接时间戳也就是计算签名的时候用到的ts;
# 签名为md5(md5(你的开发者密码)拼接上面的ts时间戳的值);ts为时间戳获取当前时间戳即可;也就是将开发者密码(AppSecret)进行一次MD5,然后将这个结果拼接上时间戳,再对整个拼接后的字符串做一次MD5
# 请求需要传递两个参数device和order:
# device[字符串]:设备唯一ID,可传多个[用,间隔],可在控制台可查看,也可通过接口拉取
# order[json字符串]:下发的命令,例如:
# {"power":1},一般为将通断器的线路接通
# {"power3":0},一般为将开关或控制器的第3条线路关闭
# {"play:gbk:16":"你好,欢迎光临"},让语音喇叭播报指定内容
# 相同产品类型的设备,命令相同,不同产品类型的命令,请到每个产品的商品页面查看
# 注意:一定要替换成正式的AppID和AppSecret,再根据实时的时间戳计算签名,请求一定需要device设备ID和order命令

import hashlib
import json
import http.client
import time
from urllib.parse import urlencode

def calculate_md5(s):
    return hashlib.md5(s.encode()).hexdigest()

def send_request():
    app_id = "开发者ID"  # 替换为实际的 AppID
    app_secret = "开发者密码"  # 替换为实际的 AppSecret
    ts = int(time.time())  # 获取当前时间戳(秒)

    # 计算签名  md5(md5(开发者密码)拼接上面的ts参数)
    sign = calculate_md5(calculate_md5(app_secret) + str(ts))

    # 构建 URL
    base_url = f"https://api.yoyoiot.cn/{app_id}/device/control/"
    params = {
        "sign": sign,
        "ts": ts
    }

    # 构建请求体数据
    device = "1878"  # 替换为实际的设备ID;可传多个[用,间隔]
    order = {"power1": 1}  # 替换为实际的命令

    request_body = {
        "device": device,
        "order": order
    }

    json_body = json.dumps(request_body)

    # 创建请求
    conn = http.client.HTTPSConnection("api.yoyoiot.cn")
    headers = {
        "Content-Type": "application/json"
    }

    # 发送请求
    conn.request("POST", f"/{app_id}/device/control/?{urlencode(params)}", json_body, headers)

    # 获取响应
    response = conn.getresponse()
    response_data = response.read().decode('utf-8')

    print("Response Status Code:", response.status)
    print("Response Body:", response_data)

    conn.close()

# 调用函数
send_request()

说明:{AppID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档。

2. 智能语音音柱|10W

如何通过Python语言对接语音播报盒_第2张图片

远程语音播报、语音提醒、语音通知、语音警报;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒等;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
支持远程音量、音色、语调、语速设置;
支持多音字、支持数字(数值、金额、手机号等)读法;
内置铃声、提示音、警示音各5种;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;
防尘防水,外形美观,安装简单;

更多...


使用Python语言调用HTTP接口控制智能语音音柱|10W的代码
以设备控制(向设备下发命令)为例

全部接口文档复制

# 核心请求地址:https://api.yoyoiot.cn/拼接你的AppID的值/device/control/?sign=拼接你计算得到的签名&拼接时间戳也就是计算签名的时候用到的ts;
# 签名为md5(md5(你的开发者密码)拼接上面的ts时间戳的值);ts为时间戳获取当前时间戳即可;也就是将开发者密码(AppSecret)进行一次MD5,然后将这个结果拼接上时间戳,再对整个拼接后的字符串做一次MD5
# 请求需要传递两个参数device和order:
# device[字符串]:设备唯一ID,可传多个[用,间隔],可在控制台可查看,也可通过接口拉取
# order[json字符串]:下发的命令,例如:
# {"power":1},一般为将通断器的线路接通
# {"power3":0},一般为将开关或控制器的第3条线路关闭
# {"play:gbk:16":"你好,欢迎光临"},让语音喇叭播报指定内容
# 相同产品类型的设备,命令相同,不同产品类型的命令,请到每个产品的商品页面查看
# 注意:一定要替换成正式的AppID和AppSecret,再根据实时的时间戳计算签名,请求一定需要device设备ID和order命令

import hashlib
import json
import http.client
import time
from urllib.parse import urlencode

def calculate_md5(s):
    return hashlib.md5(s.encode()).hexdigest()

def send_request():
    app_id = "开发者ID"  # 替换为实际的 AppID
    app_secret = "开发者密码"  # 替换为实际的 AppSecret
    ts = int(time.time())  # 获取当前时间戳(秒)

    # 计算签名  md5(md5(开发者密码)拼接上面的ts参数)
    sign = calculate_md5(calculate_md5(app_secret) + str(ts))

    # 构建 URL
    base_url = f"https://api.yoyoiot.cn/{app_id}/device/control/"
    params = {
        "sign": sign,
        "ts": ts
    }

    # 构建请求体数据
    device = "1878"  # 替换为实际的设备ID;可传多个[用,间隔]
    order = {"power1": 1}  # 替换为实际的命令

    request_body = {
        "device": device,
        "order": order
    }

    json_body = json.dumps(request_body)

    # 创建请求
    conn = http.client.HTTPSConnection("api.yoyoiot.cn")
    headers = {
        "Content-Type": "application/json"
    }

    # 发送请求
    conn.request("POST", f"/{app_id}/device/control/?{urlencode(params)}", json_body, headers)

    # 获取响应
    response = conn.getresponse()
    response_data = response.read().decode('utf-8')

    print("Response Status Code:", response.status)
    print("Response Body:", response_data)

    conn.close()

# 调用函数
send_request()

说明:{AppID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档。

产品参数对比

产品 / 版本

参数

如何通过Python语言对接语音播报盒_第3张图片

智能语音喇叭3

如何通过Python语言对接语音播报盒_第4张图片

智能语音音柱|10W
白色
白色
外壳材质
塑料
铝合金
产品尺寸
宽:80mm;长:80mm;厚:50mm
104mm宽84mm x高260mm
产品净重
105g
1.04KG
产品颜色
白色
白色
工作电压
100-250V AC(交流 / 市电)
DC 12V2A(直流)
待机功耗
0.4(静音) - 3.7(最大音量播放)W
0.4(静音) - 3.7(最大音量播放)W
安装方式
2p插头|即插即用
无线连接
WiFi IEEE 802.11 b / g / n 2.4GHz
WiFi IEEE 802.11 b / g / n 2.4GHz
产品外壳
防火V0级PC,耐高温,符合安规标准
铝合金,分隔式绝缘隔断,防止漏电风险,符合安规标准
包装清单
智能语音喇叭*1
智能音响*1 、 支架*3 、 螺丝*3 、 12V2A电源*1
发声单元
2个
2寸高音 + 4寸中低音
灵敏度
89db
频率响应
0.1-16K

你可能感兴趣的:(python,开发语言)