检索数字短语

时间:2016-02-18 15:49:28

标签: c++ sapi

我在这里发现了另一篇文章,但我无法发表评论。这是一个包含数字的语法文件。我该如何检索这些数字?我知道我可以使用wcscmp函数,但是让我们说有200个数字;这将是彼此之间的许多if else陈述。我如何能够搜索pPhrase->规则规则层次结构并分配规则指针。

注意这可以使另一条规则与另一组数字一起确定多个数字。

这是语法文件的片段;但是,我将不在引用范围内的数字改为措辞数字。

<rule name="phoneno">
  <phrase min="7" max="10">
    <ruleref name="digit" propname="digit"/>
  </phrase>
</rule>

<rule name="digit">
  <l>
    <p val="0">zero</p>
    <p val="1">one</p>
    <p val="2">two</p>
    <p val="3">three</p>
    <p val="4">four</p>
    <p val="5">five</p>
    <p val="6">six</p>
    <p val="7">seven</p>
    <p val="8">eight</p>
    <p val="9">nine</p>
  </l>
</rule>

编辑代码片段,用于检索和处理某些短语。

SPPHRASE *pElements;
std::wstring str;

// Get the phrase elements, one of which is the rule id we specified in
// the grammar.  Switch on it to figure out which command was recognized.

if (SUCCEEDED(pPrhase->GetPhrase(&pElements))) {
    SPPHRASE phrase = *pElements;
    WCHAR *pText;
    const SPPHRASEPROPERTY *pProp = phrase.pProperties;

    if (SUCCEEDED(pPhrase->GetText(SP_GETWHOLEPHRASE, SP_GETWHOLEPHRASE, TRUE, &pText, NULL))) {
        str = pText;
    }
    else {

    }
}

switch (pElements->Rule.ulId) {
    case digit:
        while (pProp != NULL) {
            if (wcscmp(L"digit", phrase.Rule.pszName) == 0) {
                if (wcscmp(L"one", pProp->pFirstChild->pszValue) == 0) {
                    pProp = pProp->pNextSibling;
                }
                else if (wcscmp(L"two", pProp->pFirstChild->pszValue) == 0) {
                    pProp = pProp->pNextSibling;
                }
                else if (wcscmp(L"three", pProp->pFirstChild->pszValue) == 0) {
                    pProp = pProp->pNextSibling;
                }
                // all the way up to nine
            }
            // now let us say there is a another digit after the first digit. 
            // so the number can be from 11 - 99, would I need to place the second digit
            // within each of the "first digit if / else if statements"?    Or is there
            // an efficient way to do this? 
            }
         break;
    }
}

1 个答案:

答案 0 :(得分:0)

在某些时候,使用microsoft的语法编译器(gc.exe)生成ID列表变得更加容易,因此您可以轻松地比较ID而不是按规则名称。代码中的最终结果如下所示:

SPPHRASE *pElements;

// Get the phrase elements, one of which is the rule id we specified in
// the grammar.  Switch on it to figure out which command was recognized.
if (SUCCEEDED(pPhrase->GetPhrase(&pElements)))
{        
    switch ( pElements->Rule.ulId )
    {
        case VID_RuleNameHere:
        {
           //Do stuff here
        }
    }
}

您可以阅读有关如何执行此操作的更多信息here.当您针对语法文件运行gc.exe时,您还需要指定/ H开关。