我的 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 文件中的所有表都将传输到输出 .csv 文件,即使我将参数的值设置为默认值。
当我调用getParameter()
函数时返回false
(即使返回值应该是参数的值,或者null
如果未找到参数)。
我尝试更改namespace
传递给函数的值,但这根本没有帮助。
我究竟做错了什么?这一定很简单,但我一生都无法弄清楚。
编辑
我尝试将value
参数setParameter()
作为字符串和数字传递;两者都有相同的结果。