LXML和XSL文档()函数



嗨,我得到了以下文件:

merge.py:

from lxml import etree
xml_input = etree.XML(open('a.xml', 'r').read())
xslt_root = etree.XML(open('merge.xsl', 'r').read())
transform = etree.XSLT(xslt_root)
print str(transform(xml_input))

合并.xsl:

<xsl:stylesheet version="1.0" 
  xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:template match="/">
        <merge>
        <xsl:copy-of select="."/>
            <xsl:copy-of select="document('b.xml')"/>        
    </merge>
    </xsl:template>

a.xml:

<?xml version="1.0" encoding="ISO-8859-1"?>
<a>
 <test id="1"/>
</a>

b.xml:

<?xml version="1.0" encoding="ISO-8859-1"?>
<b>
 <test id="2"/>
</b>   

这4个文件在同一目录中,当我调用merge.py时,我得到了错误:

lxml.etree.XSLTApplyError: Cannot resolve URI string://__STRING__XSLT__/b.xml

知道吗?我做错了什么?

您需要注册一个URI解析程序。请参阅文档。

可能是这样的(未经测试):

class FileResolver(etree.Resolver):
    def resolve(self, url, pubid, context):
        return self.resolve_filename(url, context)
parser = etree.XMLParser()
parser.resolvers.add(FileResolver())
xml_input = etree.parse(open('a.xml','r'), parser)
xslt_root = etree.parse(open('merge.xsl','r'), parser)
transform = etree.XSLT(xslt_root)
print str(transform(xml_input))

为什么不简单地这样做呢?

from lxml import etree
xml_input = etree.parse("a.xml")
xslt_root = etree.parse("merge.xsl")
transform = etree.XSLT(xslt_root)
print str(transform(xml_input))

更简单,不需要解析器。

最新更新