XSL - 修改XML导出到Excel以动态添加粗体样式

时间:2017-08-18 01:47:20

标签: xml excel xslt

我正在尝试使用XSL文件修改XML文件来创建Excel电子表格 - 我已经掌握了这项工作的基础知识,但现在需要对其进行一些自定义。 XML文件中的第6列包含一些记录的1,我想修改输出以将粗体样式应用于FlagBold字段/第6个col等于1的任何行。

这是我目前的XML:

<?xml version="1.0" encoding="utf-8"?>
<FMPXMLRESULT xmlns="http://www.filemaker.com/fmpxmlresult">
    <ERRORCODE>0</ERRORCODE>
    <PRODUCT BUILD="06-06-2017" NAME="FileMaker" VERSION="ProAdvanced 16.0.2"/>
    <METADATA>
        <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="ColumnA" TYPE="TEXT"/>
        <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="ColumnB" TYPE="TEXT"/>
        <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="ColumnC" TYPE="TEXT"/>
        <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="ColumnD" TYPE="TEXT"/>
        <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="ColumnE" TYPE="TEXT"/>
        <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="FlagBold" TYPE="TEXT"/>
    </METADATA>
    <RESULTSET FOUND="6">
        <ROW MODID="0" RECORDID="900">
            <COL>
                <DATA>Created: 15-August-2017</DATA>
            </COL>
            <COL>
                <DATA/>
            </COL>
            <COL>
                <DATA/>
            </COL>
            <COL>
                <DATA/>
            </COL>
            <COL>
                <DATA/>
            </COL>
            <COL>
                <DATA>1</DATA>
            </COL>
        </ROW>
        <ROW MODID="0" RECORDID="901">
            <COL>
                <DATA/>
            </COL>
            <COL>
                <DATA/>
            </COL>
            <COL>
                <DATA/>
            </COL>
            <COL>
                <DATA/>
            </COL>
            <COL>
                <DATA/>
            </COL>
            <COL>
                <DATA/>
            </COL>
        </ROW>
        <ROW MODID="1" RECORDID="902">
            <COL>
                <DATA>Name</DATA>
            </COL>
            <COL>
                <DATA>ID</DATA>
            </COL>
            <COL>
                <DATA>Category</DATA>
            </COL>
            <COL>
                <DATA>Number</DATA>
            </COL>
            <COL>
                <DATA>Amount</DATA>
            </COL>
            <COL>
                <DATA>1</DATA>
            </COL>
        </ROW>
        <ROW MODID="1" RECORDID="904">
            <COL>
                <DATA>Acme Corp Pty Ltd</DATA>
            </COL>
            <COL>
                <DATA>123456</DATA>
            </COL>
            <COL>
                <DATA>Category 1</DATA>
            </COL>
            <COL>
                <DATA>1</DATA>
            </COL>
            <COL>
                <DATA>$456.78</DATA>
            </COL>
            <COL>
                <DATA/>
            </COL>
        </ROW>
        <ROW MODID="1" RECORDID="905">
            <COL>
                <DATA>Demo Company Pty Ltd</DATA>
            </COL>
            <COL>
                <DATA>987654</DATA>
            </COL>
            <COL>
                <DATA>Category 2</DATA>
            </COL>
            <COL>
                <DATA>1</DATA>
            </COL>
            <COL>
                <DATA>$789.32</DATA>
            </COL>
            <COL>
                <DATA/>
            </COL>
        </ROW>
    </RESULTSET>
</FMPXMLRESULT>

在我的XSL文件中,我有这种风格:

        <Style ss:ID="MyTitleStyle">
            <Alignment ss:WrapText="0" />
            <Font  ss:Bold="1"/>
        </Style>

我在这里处理行:

<xsl:for-each select="fmp:FMPXMLRESULT/fmp:RESULTSET/fmp:ROW">
    <Row>
        <xsl:for-each select="fmp:COL">
            <Cell>
                <xsl:if test="fmp:COL[6]/fmp:DATA = 1">
                    <xsl:attribute name="ss:StyleID">MyTitleStyle</xsl:attribute>
                </xsl:if>           
                <Data ss:Type="String">
                    <xsl:value-of select="." />
                </Data>
            </Cell>
        </xsl:for-each><!-- next column -->
    </Row>
</xsl:for-each><!-- next row -->

但是我没有在创建的.xls电子表格文件中获得任何大胆的风格,也不确定我在这里出错了什么?

1 个答案:

答案 0 :(得分:0)

测试:

<xsl:if test="fmp:COL[6]/fmp:DATA = 1">

永远不会从以下语境中返回:

<xsl:for-each select="fmp:COL">

将其更改为:

<xsl:if test="../fmp:COL[6]/fmp:DATA = 1">