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不是特别熟悉,所以我可能错过了那里的一些东西。