Ссылки на сущности и lxml - PullRequest
9 голосов
/ 26 марта 2010

Вот код, который у меня есть:

from cStringIO import StringIO
from lxml import etree

xml = StringIO('''<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE root [
<!ENTITY test "This is a test">
]>
<root>
  <sub>&test;</sub>
</root>''')

d1 = etree.parse(xml)
print '%r' % d1.find('/sub').text

parser = etree.XMLParser(resolve_entities=False)
d2 = etree.parse(xml, parser=parser)
print '%r' % d2.find('/sub').text

Вот вывод:

'This is a test'
None

Как мне получить lxml, чтобы дать мне '&test;', то есть необработанную ссылку на сущность?

1 Ответ

19 голосов
/ 26 марта 2010

«Неразрешенный» объект остается дочерним узлом узла элемента sub

>>> print d2.find('/sub')[0]
&test;
>>> d2.find('/sub').getchildren()
[&test;]
...