У меня есть строка, состоящая из списка слов, которые я пытаюсь проанализировать с помощью pyparsing.
В списке всегда минимум три пункта. Исходя из этого, я хочу, чтобы pyparsing генерировал три группы, первая из которых содержит все слова до последних двух элементов, а последние две группы должны быть двумя последними элементами. Например:
"one two three four"
следует разбирать на что-то похожее:
["one two"], "three", "four"
Я могу сделать это с помощью Regex:
import pyparsing as pp
data = "one two three four"
grammar = pp.Regex(r"(?P<first>(\w+\W?)+)\s(?P<penultimate>\w+) (?P<ultimate>\w+)")
print(grammar.parseString(data).dump())
который дает:
['one two three four']
- first: one two
- penultimate: three
- ultimate: four
Моя проблема в том, что я не могу получить тот же результат с не-Regex ParserElement из-за жадного характера pyparsing, например следующего:
import pyparsing as pp
data = "one two three four"
word = pp.Word(pp.alphas)
grammar = pp.Group(pp.OneOrMore(word))("first") + word("penultimate") + word("ultimate")
grammar.parseString(data)
не работает с трассировкой:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.7/site-packages/pyparsing.py", line 1125, in parseString
raise exc
pyparsing.ParseException: Expected W:(abcd...) (at char 18), (line:1, col:19)
потому что OneOrMore проглатывает все слова в списке. Мои попытки предотвратить это жадное поведение с помощью FollowedBy или NotAny пока не увенчались успехом - какие-либо предложения относительно того, как я могу добиться желаемого поведения?