我希望解析一个表示布尔表达式的字符串。以下代码基于许多示例,并使用了 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 不是特别熟悉,所以我可能在那里遗漏了一些东西。