sebaszw
sebaszw

Reputation: 1474

How to not load the comments while parsing XML in lxml

I try to parse XML file in Python using lxml like this:

objectify.parse(xmlPath, parserWithSchema)

but XML file may contains comments in strange places:

<root>
    <text>Sam<!--comment-->ple text</text>
    <!--comment-->
    <float>1.2<!--comment-->3456</float>
</root>

It is a way to not load or delete comments before parsing?

Upvotes: 15

Views: 7572

Answers (1)

alecxe
alecxe

Reputation: 473903

Set remove_comments=True on the parser (documentation):

from lxml import etree, objectify

parser = etree.XMLParser(remove_comments=True)
tree = objectify.parse(xmlPath, parser=parser)

Or, using the makeparser() method:

parser = objectify.makeparser(remove_comments=True)
tree = objectify.parse(xmlPath, parser=parser)

Hope that helps.

Upvotes: 22

Related Questions