Pyparsing - 来自一个组的零或一个

时间:2013-06-13 11:42:01

标签: python pyparsing

如何从一组令牌中获得零或只有一个令牌?它们可以按任何顺序排列。说这是我的代码:

def parseFunc(self, string):
    firstToken = CaselessKeyword("KeyWordOne")
    secondToken = CaselessKeyword("KeyWordTwo")
    thirdToken = CaselessKeyword("KeyWordThree")

    stmt = ZeroOrMore(firstToken | secondToken | thirdToken)
    return stmt.parseString(string)

使用ZeroOrMore会出现问题,因为每个令牌都可以多次显示。 使用Optional时,它们必须按照列出的确切顺序排列。

这是我目前的解决方案:

stmt = ZeroOrMore(firstToken | secondToken | thirdToken)
tokens = stmt.parseString(string)
s = set()
for x in tokens:
    if x[0] in s: return "Error: redundant options"
    s.add(x[0])

return tokens

1 个答案:

答案 0 :(得分:4)

Optional与“零或一”相同:

stmt = Optional(firstToken | secondToken | thirdToken)

还有一个新的乘法形式,类似于正则表达式中的{min,max}

stmt = (firstToken | secondToken | thirdToken) * (0,1)

编辑:

对于任意顺序,使用Each(使用operator&定义):

stmt = (Optional(firstToken) & Optional(secondToken) & Optional(thirdToken))