>>> from pyparsing import Word, alphanums, OneOrMore, Optional, Suppress
>>> var = Word(alphanums)
>>> reg = OneOrMore(var('predictors') + Optional(Suppress('+'))) + '~' + OneOrMore(var('covariates') + Optional(Suppress('+')))
>>> string = 'y1 ~ f1 + f2 + f3'
>>> reg.parseString(string)
(['y1', '~', 'f1', 'f2', 'f3'], {'predictors': ['y1'], 'covariates': ['f1', 'f2', 'f3']})
它能够正确解析事物,但是我无法获得
predictors
和covariates
的所有值。它似乎只存储最后一个值:>>> results = reg.parseString(string)
>>> results.covariates
'f3'
>>> results['covariates']
'f3'
我想以列表的形式获取
predictors
和covariates
中的所有值。任何想法为什么会这样? 最佳答案
默认情况下,结果名称使用与Python dict类似的逻辑:如果为同一键分配了多个值,则仅保留最后分配的值。
但是,此行为可以被覆盖,具体取决于解析器如何定义结果名称。
如果使用完整的expr.setResultsName("XYZ")
形式,请添加listAllMatches=True
参数。这告诉pyparsing保留所有已解析值的列表,并将它们作为列表返回。
如果使用快捷方式expr("XYZ")
形式,请在名称末尾添加'*'
:expr("XYZ*")
。这等效于将listAllMatches
设置为True。
对于使用'*'
缩写形式的情况,在setResultsName
中位于尾随的setResultsName
:expr("name*")
vs expr.setResultsName("name", listAllMatches=True)
。如果您喜欢调用setResultsName
,则不要使用'*'
表示法,而应传递listAllMatches
参数。
关于python - pyparsing:无法从ParseResults对象获取结果,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/56668009/