Tôi đang cố gắng sử dụng pyparsing
để phân tích chức năng gọi theo hình thức:Parsing chức năng lồng nhau gọi sử dụng pyparsing
f(x, y)
Đó là dễ dàng. Nhưng kể từ đó là một phân tích cú pháp đệ quy-gốc, nó cũng sẽ dễ dàng để phân tích:
f(g(x), y)
Đó là điều tôi không thể có được. Dưới đây là một ví dụ luộc xuống:
from pyparsing import Forward, Word, alphas, alphanums, nums, ZeroOrMore, Literal
lparen = Literal("(")
rparen = Literal(")")
identifier = Word(alphas, alphanums + "_")
integer = Word(nums)
functor = identifier
# allow expression to be used recursively
expression = Forward()
arg = identifier | integer | expression
args = arg + ZeroOrMore("," + arg)
expression << functor + lparen + args + rparen
print expression.parseString("f(x, y)")
print expression.parseString("f(g(x), y)")
Và đây là kết quả:
['f', '(', 'x', ',', 'y', ')']
Traceback (most recent call last):
File "tmp.py", line 14, in <module>
print expression.parseString("f(g(x), y)")
File "/usr/local/lib/python2.6/dist-packages/pyparsing-1.5.6-py2.6.egg/pyparsing.py", line 1032, in parseString
raise exc
pyparsing.ParseException: Expected ")" (at char 3), (line:1, col:4)
Tại sao phân tích cú pháp của tôi giải thích các functor của biểu thức bên trong như một định danh độc lập?
đẹp bắt, @ Jason! – PaulMcG