检索数字短语



我在这里找到了另一篇文章,但我无法对此发表评论。它是一个包含数字的语法文件。我将如何检索数字?我知道我可以使用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;
    }
}

在某些时候,使用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
        }
    }
}

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

相关内容

最新更新