鉴于以下语法对换行符敏感,我如何忽略以空格开头的注释?
pp.LineStart() + pp.Optional(pp.White(" \t")) + '#'与以空格开头的行不匹配。

import pyparsing as pp
pp.ParserElement.setDefaultWhitespaceChars(' \t')

def Line(expr): return expr + pp.Suppress(pp.LineEnd())

foo = Line(pp.Group(pp.OneOrMore(pp.Word(pp.alphas))))

parser = pp.OneOrMore(foo)

comment = '#' + pp.restOfLine()
parser.ignore(pp.LineStart() + pp.Optional(pp.White(" \t")) + pp.Optional(comment) + pp.LineEnd())
parser.ignore(comment)

text = """

 foo abc
# comment
bar # comment
"""

results = parser.parseString(text, parseAll=True)
assert list(results[0]) == ['foo', 'abc']

text = """

foo abc
 # comment
bar
"""

results = parser.parseString(text, parseAll=True)

print "ok"

最佳答案

仅包含注释的行可以在输入中留下悬挂的行尾。将分析器更改为:

parser = pp.OneOrMore(foo | pp.LineEnd().suppress())

关于python - PyParsing,匹配以白色开头的行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/56880577/

10-12 19:07