如何从一组令牌中获得零或只有一个令牌?它们可以按任何顺序排列。说这是我的代码:
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
答案 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))