所有,
我用python PLY写了一个非常简单的解析器。它主要完成这项工作,但是对于许多输入行,我从yacc
收到语法错误。这是词法分析器和解析器代码,为了便于测试,对其进行了一些修改:
tokens = ('VAR', 'NUMBER', 'CLOSE', 'JUNK')
# Tokens
t_VAR = r'%[mM]\['
t_CLOSE = r'\]'
t_JUNK = r'.'
# Ignored characters
t_ignore = " \t\r"
def t_NUMBER(t):
r'\d+'
try:
t.value = int(t.value)
except ValueError:
print("Integer value too large %d", t.value)
t.value = 0
return t
def t_newline(t):
r'\n+'
t.lexer.lineno += t.value.count("\n")
def t_error(t):
print("Illegal character '%s'" % t.value[0])
t.lexer.skip(1)
# Build the lexer
import ply.lex as lex
lex.lex()
# Parsing rules
def p_statement(p):
'''statement : field'''
try:
print p[1]
except IndexError:
pass
def p_trash(p):
'''statement : JUNK'''
pass
def p_field(p):
'''field : VAR NUMBER CLOSE'''
#print p[1], p[2], p[3]
p[0] = p[2]
def p_error(p):
print("Syntax error at '%s'" % repr(p)) #p.value)
import ply.yacc as yacc
yacc.yacc()
对于示例:
yacc.parse('.set %m[702] $substr($currentlength,2,$currentpg)')
给出输出:Syntax error at 'LexToken(JUNK,'s',1,1)'
Syntax error at 'LexToken(JUNK,'$',1,13)'
它应该仅输出
702
。 最佳答案
您的顶级规则仅需一条语句。 p_trash
匹配第一个'。并返回一条语句,并且没有顶级规则允许它继续。您可以执行以下操作:
def p_junk(p):
'''statement | JUNK statement'''
您还可以执行以下操作(并创建语句列表):
def p_statements(p):
'''statements | statement statements
| empty'''
关于python - Python PLY解析器语法错误,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/9039445/