2012-07-19 55 views
3

我希望解析表示布尔表达式的字符串。以下代码基于许多示例,并使用pyparsing的operatorPrecedence助手。pyparsing.operatorPrecedence不会在无效字符串上产生错误

问题是,我希望代码在无法合理解析字符串时引发异常。就目前而言,许多无效表达式只是静静地传递,并返回错误的表达式。

import pyparsing 

_A = pyparsing.Literal('A') 
_B = pyparsing.Literal('B') 

bool_operand = pyparsing.Or((_A, _B)) 

precedence_list = [("NOT", 1, pyparsing.opAssoc.RIGHT), 
     ("AND", 2, pyparsing.opAssoc.LEFT), 
     ("OR", 2, pyparsing.opAssoc.LEFT),] 

bool_parser = pyparsing.operatorPrecedence(bool_operand, precedence_list) 

print bool_parser.parseString('A OR B OR NOT A') # A valid string 
print bool_parser.parseString('A NOT AND B') # an invalid string 

此输出:

[['A', 'OR', 'B', 'OR', ['NOT', 'A']]] 
['A'] 

所以第一个字符串的工作原理,但可根据需要在第二个字符串不引发异常。

任何想法,我可以做到这一点?我对pyparsing不是特别熟悉,所以我可能错过了那里的一些东西。

回答

3

更改您的A_和B_的定义以使用Keyword类而不是Literal类。

此外,当您调用parseString时,请添加parseAll=True,以便强制解析整个输入。

相关问题