0

我的 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()作为字符串和数字传递;两者都有相同的结果。

4

1 回答 1

1

我不知道 API,但http://php.net/manual/en/xsltprocessor.setparameter.php建议 PHP 传入的参数是一个字符串,所以当你这样做时$processor->setParameter(NULL, 'table-number', 1);,数字可能1会作为字符串传递给 XSLT 和在这种情况下,XSLT 中的位置谓词不起作用,除非您将它们明确写为[position() = $table-number].

于 2012-09-10T14:29:48.123 回答