我在pyparsing中遇到了这个错误。
from pyparsing import Word,alphas,nums,Or,Regex,StringEnd
ws = Regex('\s*')
dot = "."
w = Word(alphas) + (ws | dot) + StringEnd()
w.leaveWhitespace()
w.parseString('AMIT.')返回以下错误:
ParseException: Expected end of text (at char 4), (line:1, col:5)发布于 2012-02-08 15:14:40
|创建一个“匹配优先”表达式,而不是“匹配时间最长”。
第一个替代方法是正则表达式,它将匹配0个或更多空格字符。实际上,这是匹配的,所以点不会被解析。
那么下一个要解析的元素是StringEnd,但是解析位置仍然位于‘.’-所以,失败!
下面是通过将setDebug()调用添加到语法表达式中的一些更详细的输出:
>>> w = Word(alphas).setDebug() + (ws.setDebug() | dot.setDebug()) + StringEnd()
>>> w.parseString('AMIT.')
Match W:(abcd...) at loc 0(1,1)
Matched W:(abcd...) -> ['AMIT']
Match Re:('\\s*') at loc 4(1,5)
Matched Re:('\\s*') -> ['']
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "c:\python26\lib\site-packages\pyparsing-1.5.6-py2.6.egg\pyparsing.py", line 1032, in parseString
raise exc
pyparsing.ParseException: Expected end of text (at char 4), (line:1, col:5)要让你的语法正常工作,你可以:
|运算符更改为^ (匹配最长时间而不是先匹配)\s+而不是\s* (以便将match)Optional(dot)更改为\s*至少需要一个空格
一般来说,对空格的显式测试与pyparsing哲学不一致--pyparsing与re不同。
https://stackoverflow.com/questions/9188965
复制相似问题