3

我正在 wit.ai 中试用一个示例,这是链接:https ://wit.ai/Nayana-Manchi/CreditCardApp/stories

第一个故事“BalanceEnquiry”是一个基于老虎机的故事。快乐的场景运行良好。为了测试“cardnumbermissing”分支,我会输入“我想要卡上的信用卡余额,我的名字是 Nayana”。这里是卡号缺少最后 4 位数字。它要求输入卡的最后 4 位数字,然后我将输入卡的最后 4 位数字。但是这里它没有得到之前消息中发送的名称实体。

如何保存上一步发送的实体值“name”?它应该保留实体值名称,并且应该从当前对话中获取输入的最后 4 位数字,然后显示硬编码的余额。

代码和附加的图像。

如果您共享配方的客户端代码(javascript)将会很有帮助 - 构建基于插槽的机器人。

演示图像

'use strict';

let Wit = null;
let interactive = null;
try {
    // if running from repo
    Wit = require('../').Wit;
    interactive = require('../').interactive;
} catch (e) {
    Wit = require('node-wit').Wit;
    interactive = require('node-wit').interactive;
}

const accessToken = (() => {
    if (process.argv.length !== 3) {
        console.log('usage: node examples/creditcardbalance.js <wit-access-token>');
        process.exit(1);
    }
    return process.argv[2];
})();

// Quickstart example
// See https://wit.ai/ar7hur/quickstart

const firstEntityValue = (entities, entity) => {
    const val = entities && entities[entity] &&
      Array.isArray(entities[entity]) &&
      entities[entity].length > 0 &&
      entities[entity][0].value
    ;
    if (!val) {
        return null;
    }
    return typeof val === 'object' ? val.value : val;
};

const actions = {
    send(request, response) {
        const {sessionId, context, entities} = request;
        const {text, quickreplies} = response;
        return new Promise(function(resolve, reject) {
            console.log('sending...', JSON.stringify(response));
            return resolve();
        });
    },
    getBalance({context, entities}) {
    return new Promise(function(resolve, reject) {
        var name = firstEntityValue(entities, "name");
        var last4digit = firstEntityValue(entities, "Last4digits");
        
        if (name && last4digit) {
            context.name = name;
            context.last4digit = last4digit;
            context.balance = 'Rs.10000' + name + last4digit; // we should call a credit card API here
            delete context.cardnumbermissing;
        }
        else {
            context.cardnumbermissing = true;
            context.name = name;
            delete context.balance;
        }
        return resolve(context);
    });
},
};

const client = new Wit({accessToken, actions});
interactive(client);
// JavaScript source code

4

1 回答 1

0

我有一个类似的问题,发生的事情是 firstEntityValue 只从最初的对话中提取,所以我实际上每次调用它来设置变量时都会删除以前的变量。如果已经有上下文,我必须让函数知道上下文,而不是使用 firstEntityValue 设置这些变量。

于 2016-09-21T21:52:08.267 回答