У меня есть набор супер простых XML файлов для синтаксического анализа... но... они используют настраиваемые сущности. Мне не нужно сопоставлять их символам, но я хочу разобрать и действовать на каждом из них. Например:
<Style name="admin-5678">
<Rule>
<Filter>[admin_level]='5'</Filter>
&maxscale_zoom11;
</Rule>
</Style>
Существует дразнящий намек на http://effbot.org/elementtree/elementtree-xmlparser.htm, что XMLParser имеет ограниченную поддержку сущностей, но я не могу найти упомянутые методы, все дает ошибки:
#!/usr/bin/python
##
## Where the entity support as documented at:
## http://effbot.org/elementtree/elementtree-xmlparser.htm
## In Python 2.7.1+ ?
##
from pprint import pprint
from xml.etree import ElementTree
from cStringIO import StringIO
parser = ElementTree.ElementTree()
#parser.entity["maxscale_zoom11"] = unichr(160)
testf = StringIO('<foo>&maxscale_zoom11;</foo>')
tree = parser.parse(testf)
#tree = parser.parse(testf,"XMLParser")
for node in tree.iter('foo'):
print node.text
Что в зависимости от того, как вы настраиваете комментарии, дает:
xml.etree.ElementTree.ParseError: undefined entity: line 1, column 5
или
AttributeError: 'ElementTree' object has no attribute 'entity'
или
AttributeError: 'str' object has no attribute 'feed'
Для тех, кому интересно, XML из проекта mapa OpenStreetMap.