我的XSLT样式表有以下XML(请注意table-number
参数:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:tet="http://www.pdflib.com/XML/TET3/TET-3.0">
<xsl:output method="text" />
<xsl:param name="table-number" select="1" />
<xsl:param name="page-number" select="0" />
<xsl:param name="separator-char" select="','" />
<xsl:variable name="double-quote">"</xsl:variable>
<xsl:template match="/">
<xsl:if test="tet:TET/tet:Document/tet:Pages/tet:Page/tet:Content[not(@granularity = 'word' or @granularity = 'page')]">
<xsl:message terminate="yes">
<xsl:text>Stylesheet table.xsl processing TETML for document '</xsl:text>
<xsl:value-of select="tet:TET/tet:Document/@filename" />
<xsl:text>': this stylesheet requires word info in TETML.</xsl:text>
<xsl:text>Create the input in page mode "word" or "wordplus".</xsl:text>
</xsl:message>
</xsl:if>
<xsl:choose>
<xsl:when test="$page-number = 0">
<xsl:variable name="table" select="(tet:TET/tet:Document/tet:Pages/tet:Page//tet:Table)[$table-number]"/>
<xsl:if test="count($table) = 0">
<xsl:call-template name="table-not-found" />
</xsl:if>
<xsl:apply-templates select="$table" />
</xsl:when>
<xsl:otherwise>
<xsl:variable name="table" select="(tet:TET/tet:Document/tet:Pages/tet:Page[@number = $page-number]//tet:Table)[$table-number]"/>
<xsl:if test="count($table) = 0">
<xsl:call-template name="table-not-found" />
</xsl:if>
<xsl:apply-templates select="$table" />
</xsl:otherwise>
</xsl:choose>
</xsl:template>
.
.
.
</stylesheet>
以下PHP代码在给定的XML输入文件上执行XSLT:
protected function tetml_to_csv() {
$processor = new XSLTProcessor();
$xsl = new DOMDocument();
$xsl->load(realpath('./path/to/xslt/tetml_to_csv.xsl'), LIBXML_NOCDATA);
$processor->importStylesheet($xsl);
$tetml = file_get_contents($this->tetmlDoc);
$tetml = new DOMDocument();
$tetml->load($this->tetmlDoc);
//var_dump($processor->getParameter('xsl', 'table-number'));
//exit();
$processor->setParameter(NULL, 'table-number', 1);
file_put_contents($this->filepath . 'output.csv', $processor->transformToXml($tetml));
unlink($this->tetmlDoc);
}
当我在不调用setParameter()
的情况下运行代码时,XSLT只将输入XML中的第一个表放入输出.csv文件中(这是预期的行为)。
但是,当我在执行转换之前调用setParameter()
时,输入XML文件中的 ALL 表将传输到输出.csv文件,即使我设置了该值参数为默认值。
当我调用getParameter()
时,函数返回false
(即使返回值应该是参数的值,如果找不到参数,则返回null
) 。
我尝试更改传递给函数的namespace
的值,但这根本没有帮助。
我做错了什么?它必须是简单的东西,但我不能为我的生活弄明白。
修改
我尝试将value
的{{1}}参数作为字符串和数字传递;两者都有相同的结果。
答案 0 :(得分:1)
我不知道API,但是http://php.net/manual/en/xsltprocessor.setparameter.php表明PHP传入的参数是一个字符串,因此当您执行$processor->setParameter(NULL, 'table-number', 1);
时,数字1
作为字符串传递给XSLT在这种情况下,XSLT中的位置谓词不起作用,除非您明确地将它们写为[position() = $table-number]
。