尝试分析赋值语法时出现简约解析器错误

2024-10-03 02:40:50 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在使用Python Parsimonious Parser为我正在设计的一种简单语言构建一个解释器。我看了这个tutorial video,这很有帮助,现在我正在慢慢修改代码以符合我自己的规则。我被一个最初定义为:

def assignment(self, node, children):
    'assignment = lvalue "=" expr'
    lvalue, _, expr = children
    self.env[lvalue] = expr
    return expr

我用以下语法稍微修改了一下规则:

^{pr2}$

例如,我希望解析器计算SET a, 7,与a = 7相同,并将值7绑定到名称a。但是,当我试图解析它时,我从简约库中得到以下错误:

parsimonious.exceptions.IncompleteParseError: Rule 'program' matched in its 
entirety, but it didn't consume all the text. The non-matching portion of 
the text begins with 'SET a, 7' (line 1, column 1).

我对解析/词法分析相当陌生,不完全确定是否正确定义了规则。希望有更多解析/词法分析经验的人能帮助我正确定义规则并解释我哪里出错了。或许还向我解释一下节俭的错误?在


Tags: thetextself语言parser定义规则错误
1条回答
网友
1楼 · 发布于 2024-10-03 02:40:50

当我试图解析SET a, 7时,我的lvalue规则没有考虑SET和左值a之间的空白。这是因为我将lvalue规则定义为'lvalue = ~"[A-Za-z]+" _',它不考虑名称前的空格。我将赋值规则重新定义如下,以考虑GET和名称之间的空白:

'setvar = "SETVAR" _ lvalue _ "," _ expr'

吝啬似乎更喜欢这样。在

相关问题 更多 >