3

今、私はpyparsing単純な接尾辞式を解析するために使用し始めたところです。現時点では、私はここまで到達しました:

from pyparsing import *
integer = Word(nums)
op = Word("+-*/^", max=1)
space = Word(" ")
expr = Word(nums)+space+Word(nums)+space+op
parsed = expr.parseString("3 4 *")
print parsed

しかし、実行すると、次のように出力されます。

Traceback (most recent call last):
  File "star_parse.py", line 6, in <module>
    parsed = expr.parseString("3 4 *")
  File "/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/pyparsing-1.5.5-py2.6.egg/pyparsing.py", line 1100, in parseString
    raise exc
pyparsing.ParseException: Expected W:( ) (at char 2), (line:1, col:3)

私は何が間違っているのですか?

4

2 に答える 2

6

空白はデフォルトで処理されます。便利なものもありますoneOf

from pyparsing import *
integer = Word(nums)
op = oneOf('* + - / ^')
expr = integer + integer + op
parsed = expr.parseString("3 4 *")
print parsed
于 2011-06-14T06:42:43.177 に答える
4

空白はpyparserによって無視されます。Whiteクラスを使用して、空白を明示的にテストできます。

ただし、おそらく探している表現は次のとおりです。

expr = integer + integer + op

http://packages.python.org/pyparsing/pyparsing.pyparsing.White-class.html

于 2011-06-14T06:47:46.217 に答える