2012-01-12 59 views
6

嗨,我得到了以下文件: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)) 

merge.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 

任何想法?我做錯了什麼?

+0

如果我使用,我得到了lxml.etree.XSLTApplyError:無法解析URI文件://b.xml – Seb 2012-01-12 08:33:03

回答

8

您需要註冊一個URI解析器。請參閱the documentation

大概是這樣的(未經測試):

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)) 
+0

嗨弗朗西斯,謝謝你幫助我。我有一個問題,但如何將輸出html保存爲html文件? – Christopher 2013-10-11 05:25:49

6

爲什麼就不能這樣做呢?

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)) 

更簡單,不需要解析器。