1

我正在尝试使用 aws lex 创建一个语音机器人。

其中一个意图响应是“您的事件 INC11111111 已关闭”(文本)。

上述响应来自 lambda 函数。请检查下面的代码。

let response = (event, data) => {
    let lambda_response = {     
   "sessionAttributes": {
      "incidentNo":  event.currentIntent.slots.INCIDENT_NO,
    },   
    "dialogAction": {     
        "type": "Close",
        "fulfillmentState": "Fulfilled",
        "message": {       
           "contentType": "PlainText",
           "content": "Hi " + data["User ID"].split('.')[0]+", Your Incident Number " +  "INC"+event.currentIntent.slots.INCIDENT_NO+ " is ," + data["Status"]
        },    
     } 
    };

    return lambda_response;
};

前事故编号:INC11111111

但是语音输出是“您的事件 INC 1 千万 110 万 11,000 100 11 已关闭”。

我所期待的是“您的事件INC ONE ONE ONE ONE ONE ONE ONE 已关闭。提前谢谢您。

4

1 回答 1

1

您需要使用SSML(语音合成标记语言)

使用 SSML 标签,您可以自定义和控制语音的各个方面,例如发音、音量和语速。

您可以在 SSML 中使用多种指令以不同方式发音。在您的情况下say-as,指令可能很有用。

根据问题编辑,尝试这些更改

    "message": {       
       "contentType": "SSML",
       "content": "<speak> Hi " + data["User ID"].split('.')[0]+", Your Incident Number <say-as interpret-as="characters">" +  "INC"+event.currentIntent.slots.INCIDENT_NO+ "</say-as> is ," + data["Status"] +"</speak>"
    },    

相关阅读:宣布 Amazon Lex 中的响应功能和文本响应中的 SSML 支持

于 2019-09-23T10:00:06.607 回答