3

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

4

1 回答 1

3

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

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

于 2012-07-19T16:25:39.970 回答