python - "FailedParse: [...] Expecting end of text"尝试解析 grako 中带括号的表达式时

标签 python ebnf grako

search_query.ebnf 中,我对 grako 3.14.0 有以下语法定义:

@@grammar :: SearchQuery

start = search_query $;

search_query = parenthesized_query | combined_query | search_term;
parenthesized_query = '(' search_query ')';
combined_query = search_query binary_operator search_query;
binary_operator = '&' | '|';
search_term = /\w+/;

我生成解析器

grako search_query.ebnf --outfile search_query_parser.py

结果符合我对这些输入的预期:

import search_query_parser

parser = search_query_parser.SearchQueryParser()
parser.parse('a')  # -> 'a'
parser.parse('(a)')  # -> ['(', 'a', ')']
parser.parse('a & b')  # -> ['a', '&', 'b']
parser.parse('a | b')  # -> ['a', '|', 'b']
parser.parse('(a|b)&c')  # -> ['(', ['a', '|', 'b'], ')', '&', 'c']

但是如果我在运算符的右侧有一个带括号的表达式,解析器会给我一条错误消息:

parser.parse('c&(a|b)')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/home/das-g/.virtualenvs/tmp-d0fd5a9428f7612a/search_query_parser.py", line 82, in parse
    return super(SearchQueryParser, self).parse(text, *args, **kwargs)
  File "/home/das-g/.virtualenvs/tmp-d0fd5a9428f7612a/lib/python3.5/site-packages/grako/contexts.py", line 227, in parse
    result = rule()
  File "/home/das-g/.virtualenvs/tmp-d0fd5a9428f7612a/lib/python3.5/site-packages/grako/contexts.py", line 86, in wrapper
    return self._call(rule, name, params, kwparams)
  File "/home/das-g/.virtualenvs/tmp-d0fd5a9428f7612a/lib/python3.5/site-packages/grako/contexts.py", line 475, in _call
    node, newpos, newstate = self._invoke_rule(rule, name, params, kwparams)
  File "/home/das-g/.virtualenvs/tmp-d0fd5a9428f7612a/lib/python3.5/site-packages/grako/contexts.py", line 511, in _invoke_rule
    rule(self)
  File "/home/das-g/.virtualenvs/tmp-d0fd5a9428f7612a/search_query_parser.py", line 87, in _start_
    self._check_eof()
  File "/home/das-g/.virtualenvs/tmp-d0fd5a9428f7612a/lib/python3.5/site-packages/grako/contexts.py", line 650, in _check_eof
    self._error('Expecting end of text.')
  File "/home/das-g/.virtualenvs/tmp-d0fd5a9428f7612a/lib/python3.5/site-packages/grako/contexts.py", line 450, in _error
    item
grako.exceptions.FailedParse: (1:2) Expecting end of text. :
c&(a|b)
 ^
start

我做错了什么吗?

最佳答案

Am I doing something wrong?

我不这么认为。

这看起来像 known buggrako 中有关“左递归”的内容。

错误中提到的解决方法似乎也适用于您的情况:

@@grammar :: SearchQuery

start = search_query $;

search_query = parenthesized_query | combined_query | search_term;
parenthesized_query = '(' search_query | search_term ')';  ## Workaround
combined_query = search_query binary_operator search_query;
binary_operator = '&' | '|';
search_term = /\w+/;

即在括号内明确提及 search_term,即使 search_query 规则也应该能够生成它。

关于python - "FailedParse: [...] Expecting end of text"尝试解析 grako 中带括号的表达式时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39454140/

相关文章:

python - 设置QBoxLayout最大尺寸?

python - Django ORM : How to use Counter with annotate

lexer - 为什么是 'a' 。 ANTLR 中的 .'z' 匹配 $ 或 £ 等通配符

python - 如何在ebnf语法中实现不重复的规则组合?

python - 解析一个或多个具有有用错误的表达式

python - 有什么好的 Python 程序集生成模块吗?

python - tkinter Treeview 小部件插入数据

scala - 语法、Scala 解析组合器和无序集

python - 使用 simpleparse EBNF 解析 nuke 脚本