2017-06-01 6 views
0

Da XML:xsl fo passende Attributwerte

<expdur-entry><itemno id="exp-item1">1</itemno><maintenance lvl="f"/> 
<nsn><fsc>1130</fsc><niin>00-2X3-1</niin></nsn><name>Beeswax</name><desc></desc><partno>Pure Beeswax</partno><cageno>X1148</cageno><ui>LB</ui></expdur-entry> 

<expdur-entry><itemno id="exp-item2">2</itemno><maintenance lvl="f"/><nsn><fsc>X3X0</fsc> 
<niin>00-221-082</niin></nsn><name>Cloth, Abrasive</name><desc></desc><partno>L9-C-4X8</partno><cageno>81348</cageno> 
<ui>EA</ui></expdur-entry> 

<expdur-entry><itemno id="exp-item6">3</itemno> 
<maintenance lvl="f"/><nsn><fsc>130</fsc><niin>00-13-1802</niin></nsn> 
<name>Cloth, Duck</name><desc></desc><partno>L9-C-433XCL 2 FGX04</partno><cageno></cageno><ui>YD</ui></expdur-entry> 

<expdur-entry><itemno id="exp-item49">4</itemno><maintenance lvl="f"/> 
<nsn><fsc>2X81</fsc><niin>01-331-2212</niin></nsn><name>Tape, Textile, 
Nylon</name><desc></desc><partno>123-T-X38</partno> 
<cageno></cageno><ui>YD</ui></expdur-entry> 

<expdur-entry> 
<itemno id="exp-item46">5</itemno><maintenance lvl="f"/><nsn><fsc></fsc><niin></niin></nsn><name>Cloth, Nylon Diamond Weave</name><desc></desc><partno>11-1-13</partno> 
<cageno></cageno><ui></ui></expdur-entry> 

<expdur-entry><itemno id="exp-item45">6</itemno><maintenance lvl="f"/><nsn><fsc></fsc><niin></niin></nsn> 
<name>Cloth, Parachute, Nylon</name><desc></desc> 
<partno>L9-C-4438, TY V</partno><cageno></cageno><ui></ui> 
</expdur-entry> 

<expdur-entry><itemno id="exp-item117">7</itemno> 
<maintenance lvl="f"/><nsn><fsc>TBD</fsc><niin></niin></nsn><name>Cord, Nylon, Type X1</name><desc></desc><partno>L9-C-X1X</partno> 
<cageno></cageno><ui>YD</ui></expdur-entry> 

und

<bulk_itemswp> 
<pi.item><qty>.08 YD</qty><common_part_ref idref="exp-item49"/> 
</pi.item></bulk_itemswp> 

Ich bin auf pi.item und ich mag <fsc> und <niin> vom <expdur-entry> mit den <itemno> dem ziehen @id entsprechen die @idref von <common_part_ref>. In diesem Fall ist es <itemno id="exp-item49">

Ich dachte, ich so etwas wie dies in der <pi.item> Vorlage tun könnte:

<xsl:apply-templates select="//expdur-entry/itemno[@id=common_part_ref/@idref]" mode="bulk"> 

aber das hat nicht funktioniert. Der XSL-FO funktioniert, aber ich bezweifle, dass es der beste Weg ist. Ich würde es vorziehen, wenn möglich die Syntax der Auswahlklausel oben zu korrigieren.

Hier ist meine XSLFO.

<xsl:template match="pi.item"> 
     <fo:table-row> 
      <xsl:choose> 
      <xsl:when test="common_part_ref"> 
       <xsl:apply-templates select="//expdur-entry/itemno" mode="bulk"> 
       <xsl:with-param name="id"> 
        <xsl:value-of select="common_part_ref/@idref"/> 
       </xsl:with-param> 
       </xsl:apply-templates> 
      </xsl:when> 
      <xsl:otherwise /> 
      </xsl:choose> 
     </fo:table-row> 
    </xsl:template> 

<xsl:template match="expdur-entry/itemno" mode="bulk"> 
<xsl:param name="id"/> 
    <xsl:if test="@id = $id"> 
    <fo:table-cell> 
     <fo:block> 
      <xsl:value-of disable-output-escaping="no" select="../nsn/fsc"/> 
      <xsl:text disable-output-escaping="no">-</xsl:text> 
      <xsl:value-of disable-output-escaping="no" select="normalize-space(../nsn/niin)"/> 
     </fo:block> 
    </fo:table-cell> 
    </xsl:if> 
</xsl:template> 
+1

Da niemand kann eine unstrukturierte Wand des Textes lesen und verstehen Bitte spreizen Sie Ihre Eingabe-XML beim nächsten Mal richtig ein. – Tomalak

Antwort

1

Die current() XSLT-Funktion löst genau dieses Problem:

<xsl:template match="pi.item"> 
    <fo:table-row> 
     <xsl:apply-templates select="//expdur-entry/itemno[ 
      @id = current()/common_part_ref/@idref 
     ]" mode="bulk" /> 
    </fo:table-row> 
</xsl:template> 

<xsl:template match="expdur-entry/itemno" mode="bulk"> 
    <fo:table-cell> 
     <fo:block> 
      <xsl:value-of select="concat(../nsn/fsc, '-', normalize-space(../nsn/niin))" /> 
     </fo:block> 
    </fo:table-cell> 
</xsl:template> 
+0

Perfect, danke, Tomalak – Caroline

0

Eine weitere Option ist ein xsl:key zu verwenden ...

<xsl:key name="expdurByID" match="expdur-entry" use="itemno/@id"/> 

<xsl:template match="pi.item"> 
    <fo:table-row> 
    <xsl:apply-templates 
     select="key('expdurByID',common_part_ref/@idref)" mode="bulk"/> 
    </fo:table-row> 
</xsl:template> 

<xsl:template match="expdur-entry" mode="bulk"> 
    <fo:table-cell> 
    <fo:block> 
     <xsl:value-of select="concat(normalize-space(nsn/fsc), 
     '-',normalize-space(nsn/niin))"/> 
    </fo:block> 
    </fo:table-cell> 
</xsl:template> 
+0

Danke, Daniel, ich werde es versuchen! – Caroline