1

私は xslt が初めてで、学習しようとしています。データ xml を変換し、出力 xml を Adob​​e フォームにバインドすることに焦点を当てます。

次の構造のxmlがあります。

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<envelope xmlns="http://www.mydata.de/xem/reporting/datafile">
<sources>
    <source>
        <data>
            <REPORT>
                <EM_ESOURCE>
                    <EM_ES_MEASURE>
                        <ID>1037343</ID>
                        <ES_ID>1006222</ES_ID>
                        <ES_NAME>MFC-D-002</ES_NAME>
                        <EM_MAT_NAME>Cyprinella leedsi</EM_MAT_NAME>
                        <START_DATE>1/19/98</START_DATE>
                        <LABORATORY>Thornton</LABORATORY>
                        <LC50>&gt;100%</LC50>
                        <TESTTYPE/>
                        <IC25/>
                    </EM_ES_MEASURE>
                    <EM_ES_MEASURE>
                        <ID>1037344</ID>
                        <ES_ID>1006222</ES_ID>
                        <ES_NAME>MFC-D-002</ES_NAME>
                        <EM_MAT_NAME>C Dubia</EM_MAT_NAME>
                        <START_DATE>3/2/98</START_DATE>
                        <LABORATORY>Thornton</LABORATORY>
                        <LC50>&gt;120%</LC50>
                        <TESTTYPE>Routine</TESTTYPE>
                        <IC25/>
                    </EM_ES_MEASURE>
                </EM_ESOURCE>
            </REPORT>
        </data>
    </source>
</sources>

これは、クエリの 1 つの結果です。アドビのレポートでは、クエリが返す内容に関係なく、資料を常に特定の順序で表示する必要があります。そこで、xsl の材料の順序を内部的にハードコーディングし、このリストをループしてから、データ xml から対応する「LC50」値を取得することにしました。

以下は、私が開始したxslです。

<?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:rep="http://www.technidata.de/xem/reporting/datafile"
xmlns:s="http:/materials.data"
xmlns:java="http://xml.apache.org/xslt/java">
<xsl:output method="html" omit-xml-declaration="yes" encoding="UTF-8"/>      
<!-- Suppress copy of restrictions -->
<!--xsl:template match="text()|@*"/-->  
<xsl:key name="material-lookup" match="s:material" use="s:name"/>
<xsl:template match="/">
 <REPORT>
        <HEADERS>
            <STARTDATE><xsl:value-of select="substring(/rep:envelope/rep:sources/rep:restrictions/rep:START_DATE,1,10)"/></STARTDATE>
            <ENDDATE><xsl:value-of select="substring(/rep:envelope/rep:sources/rep:restrictions/rep:START_DATE,16,24)"/></ENDDATE>
            <FACILITY><xsl:value-of select="normalize-space(/rep:envelope/rep:sources/rep:restrictions/rep:ID_ATTRIBUTE_ID_NAME)"/></FACILITY>
        </HEADERS>
        <MATERIALS>         
        </MATERIALS>
         </REPORT></xsl:template>
     <s:materials>
<s:material>
    <s:name>Cyprinella leedsi</s:name>
    <s:parameter>LC(ROUTINE) </s:parameter>
</s:material>
 <s:material>
    <s:name>C Dubia</s:name>
    <s:parameter>LC50(ROUTINE) </s:parameter>
 </s:material>
</s:materials>
</xsl:stylesheet>

xslt で定義された順序で材料を MATERIALS ノードに入力する方法と、データ xml からの対応する LC50 値を入力する方法がわかりません。

4

1 に答える 1

0

関数を使用document('')して、XSLT ファイル自体に XPath します。

于 2012-09-18T13:07:01.067 に答える