gpt4 book ai didi

python - pyparsing:组合多个元素的setResultsName

转载 作者:行者123 更新时间:2023-11-28 21:10:00 25 4
gpt4 key购买 nike

这是我正在解析的文本:

x ~ normal(mu, 1)
y ~ normal(mu2, 1)

解析器匹配这些行使用:

model_definition = Group(identifier.setResultsName('random_variable_name') + '~' + expression).setResultsName('model_definition')

// end of line: .setResultsName('model_definition')

问题是当有两个模型定义时,它们没有在 ParseResults 对象中单独命名:

enter image description here

看起来第一个被第二个覆盖了。我命名它们的原因是为了使执行行更容易 - 这样我(希望)不必弄清楚在评估时发生了什么 - 解析器已经标记了所有内容。如何让两个 model_definition 都被标记?如果 model_definition 包含找到的每个模型定义的列表,那就太好了。

以防万一,这里还有一些我的代码:

model_definition = Group(identifier.setResultsName('random_variable_name') + '~' + expression).setResultsName('model_definition')
expression << Or([function_application, number, identifier, list_literal, probability_expression])
statement = Optional(newline) + Or([model_definition, assignment, function_application]) + Optional(newline)
line = OneOrMore('\n').suppress()
comment = Group('#' + SkipTo(newline)).suppress()
program = OneOrMore(Or([line, statement, comment]))
ast = program.parseString(input_string)
return ast

最佳答案

据我所知没有记录,但我在 pyparsing.py 中找到了一些东西:enter image description here

我将 .setResultsName('model_definition') 更改为 .setResultsName('model_definition*'),它们正确列出了!

enter image description here

编辑:已记录,但它是您传递给 setResultsName 的标志:

setResultsName( string, listAllMatches=False ) - name to be given to tokens matching the element; if multiple tokens within a repetition group (such as ZeroOrMore or delimitedList) the default is to return only the last matching token - if listAllMatches is set to True, then a list of matching tokens is returned.

关于python - pyparsing:组合多个元素的setResultsName,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37329296/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com