我已经包含了以下源代码,这是我目前的完整项目。到目前为止,我所做的是一个终端界面,我在其中输入一个短语,然后接收响应(来自 AIML 数据库),接收每个字母,并为该字母一个接一个地播放 .mp3 声音以制作 BASIC 翻译器(此处为 R2D2)。有几个问题。第一个是我第一次输入一个短语时它工作正常(因为它完美地翻译了输出),但随后遇到索引错误并且终端关闭。(见图 1)我不知道它有什么问题,但怀疑它可能是我的 while 循环有问题。
我遇到的另一个问题是我打算将它与语音界面一起使用,所以我说了什么,它通过 STT 引擎运行,然后将我所说的输出为字符串。我希望将该字符串作为 PyAIML 的输入,然后像在该程序中一样从其中获取响应并对其进行翻译。我遇到的问题是如何创建一个变量,然后可以将其用作 PyAIML 的输入。有什么想法我会怎么做?
import aiml
import os
import time
def translate():
if char == 'a':
os.system("start a.mp3")
elif char == 'b':
os.system("start b.mp3")
#This continues for all the letters of the alphabet - you get the idea
else:
time.sleep(0.1),
k = aiml.Kernel()
k.learn("std-startup.xml")
k.respond("load aiml b")
while True:
string = k.respond(raw_input("> "))
input = string.lower()
numChar = len(input)
n = 0
m = 0
char = input[n]
while m < numChar:
translate()
time.sleep(0.25),
n = n + 1
char = input[n]
m = m + 1
注意:响应确实有效;翻译输出后出现此错误。