我正在学习XSLT,作为练习,我试图获得http://ptchan.org/fa/的顶部链接,即{al,az,fa,ga,li,tm}。为此,我创建了以下XSL模板:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns="http://www.w3.org/1999/xhtml"
xmlns:xhtml="http://www.w3.org/1999/xhtml">
<xsl:template match="/">
<html>
<body>
<h2>Links</h2>
<table border="1">
<tr bgcolor="#9acd32">
<th>Title</th>
<th>URL</th>
</tr>
<xsl:for-each select="//div[@class='navbar']/a">
<tr>
<td><xsl:value-of select="self::node()"/></td>
<td><xsl:value-of select="@href"/></td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
我还创建了一个dummy XML文件,代表我想要通过curl http://ptchan.org/fa/ | tidy -utf8 -asxml
生成的regular file中的节点。使用xsltproc
进行转换可以使用虚拟文件,但不能使用常规文件。经过一些谷歌搜索后,我发现源文件中的(1)DOCTYPE和(2)
导致了问题,但即使在删除它们之后,也不会发生转换。
关于我做错了什么以及如何转换该文件的任何想法?
谢谢!
答案 0 :(得分:0)
由于您使用的是xsltproc
,最简单的方法就是使用-html
命令行开关,它应该能够直接处理“未经过处理的”HTML输入。
答案 1 :(得分:0)
问题是没有指定名称空间。文档中没有div,但是xhtml:divs。