如何解决在亚马逊 alexa 技能 Python 上导入文本文件
对不起我的英语。
我是 Alexa 技能实施的新手。
我想将一个文本文件(已放置在 AWS S3 存储中)导入代码中,以便能够读取它并将其插入到数据帧中,但我无法做到。
class testIntent(AbstractRequestHandler):
def can_handle(self,handler_input):
# type: (HandlerInput) -> bool
return ask_utils.is_intent_name("test")(handler_input)
def handle(self,handler_input):
# type: (HandlerInput) -> Response
res = utilis.create_presigned_url("Media/test.txt")
return (
handler_input.response_builder.speak("{}".format(res)).response
)
当技能运行时,输出是“抱歉,我无法按照您的要求执行。请重试。”
有人可以帮我吗?
解决方法
utils 中的预签名 URL 将传递对媒体的引用。它没有通过实际内容。它适用于带有 responsebuilder.setCard() 或 ssml 标签的图像/音频文件。
但是 responsebuilder.speak() 对纯文本的工作方式有点不同。您需要传递内容而不是对内容的引用。
示例:
S3 bucket > mytext.txt > ["content abcd"]
目前您正在通过
responsebuilder.speak(s3-mybucket-mytext.txt) //path
你需要通过:
responsebuilder.speak("content abcd") //content. read it using boto3
使用 boto3 客户端连接到文件:refer here
配置 S3 存储桶 > 获取文件 > 执行读取操作 > 一旦文本在 lambda 中,您可以使用 responsebuilder.speak() 将其发送给 Alexa
或者如果文件是静态的,您可以将文本文件放在代码本身中。使用文件模块导入文件。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。