2016-07-04 3 views
0

У меня возникли проблемы с выяснением того, как группировать дочерние узлы в цикле for, как вопрос. Исходный XML выглядит следующим образом (некоторые узлы опущены):Группа XSLT дочерними узлами под каждым родителем

<Report> 
<LAC_SalesOrderId> 
     <APL> 
      <LAC_Customer>09680001</LAC_Customer> 
     </APL> 
     <Detail> 
      <LACRecId_DONOT_CHANGE_Textbox169>5637144820</LACRecId_DONOT_CHANGE_Textbox169> 
      <LAC_MarkupTransLines> 
       <MarkupTrans> 
        <Detail_Collection> 
         <Detail> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>10,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </Detail> 
         <Detail> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Frakt</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>10,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </Detail> 
         <Detail> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>10,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </Detail> 
        </Detail_Collection> 
       </MarkupTrans> 
      </LAC_MarkupTransLines> 
     </Detail> 
    </LAC_SalesOrderId> 
    <LAC_SalesOrderId> 
     <APL> 
      <LAC_Customer>09680002</LAC_Customer> 
     </APL> 
     <Detail> 
      <LACRecId_DONOT_CHANGE_Textbox169>5637144821</LACRecId_DONOT_CHANGE_Textbox169> 
      <LAC_MarkupTransLines> 
       <MarkupTrans> 
        <Detail_Collection> 
         <Detail> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>20,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </Detail> 
         <Detail> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Frakt</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>30,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </Detail> 
         <Detail> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>20,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </Detail> 
        </Detail_Collection> 
       </MarkupTrans> 
      </LAC_MarkupTransLines> 
     </Detail> 
    </LAC_SalesOrderId> 
</Report> 

желаемый результат будет:

<Report> 
    <LAC_SalesOrderId> 
     <APL> 
      <LAC_Customer>09680001</LAC_Customer> 
     </APL> 
     <Detail> 
      <LACRecId_DONOT_CHANGE_Textbox169>5637144820</LACRecId_DONOT_CHANGE_Textbox169> 
      <LAC_MarkupTransLines> 
       <MarkupTrans> 
        <Detail_Collection> 
         <MarkupCode> 
          <Code>Avgift</Code> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>10,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>10,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </MarkupCode> 
         <MarkupCode> 
          <Code>Frakt</Code> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Frakt</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>10,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </MarkupCode> 
        </Detail_Collection> 
       </MarkupTrans> 
      </LAC_MarkupTransLines> 
     </Detail> 
    </LAC_SalesOrderId> 
    <LAC_SalesOrderId> 
     <APL> 
      <LAC_Customer>09680002</LAC_Customer> 
     </APL> 
     <Detail> 
      <LACRecId_DONOT_CHANGE_Textbox169>5637144821</LACRecId_DONOT_CHANGE_Textbox169> 
      <LAC_MarkupTransLines> 
       <MarkupTrans> 
        <Detail_Collection> 
         <MarkupCode> 
          <Code>Avgift</Code> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>20,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>20,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </MarkupCode> 
         <MarkupCode> 
          <Code>Frakt</Code> 
          <MarkupTrans_Detail> 
           <FIELD_MarkupTrans_MarkupCode>Frakt</FIELD_MarkupTrans_MarkupCode> 
           <FIELD_MarkupTrans_Value>30,00</FIELD_MarkupTrans_Value> 
          </MarkupTrans_Detail> 
         </MarkupCode> 
        </Detail_Collection> 
       </MarkupTrans> 
      </LAC_MarkupTransLines> 
     </Detail> 
    </LAC_SalesOrderId> 
</Report> 

До сих пор у меня этот XSLT:

<?xml version="1.0" encoding="UTF-8"?> 
<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
    <xsl:key name="groups" match="//FIELD_MarkupTrans_MarkupCode" use="."/> 


    <xsl:template match="@* | node()"> 
     <xsl:copy> 
      <xsl:apply-templates select="@* | node()"/> 
     </xsl:copy> 
    </xsl:template> 


    <xsl:template match="//LAC_MarkupTransLines/MarkupTrans/Detail_Collection"> 
     <Detail_Collection> 
      <xsl:apply-templates select="Detail/MarkupTrans_Detail/FIELD_MarkupTrans_MarkupCode[generate-id() = generate-id(key('groups', .)[1])]"/> 
     </Detail_Collection> 
    </xsl:template> 

    <xsl:template match="FIELD_MarkupTrans_MarkupCode"> 
     <xsl:variable name="currentGroup" select="."/> 
     <MarkupCode> 
      <xsl:copy-of select="../FIELD_MarkupTrans_MarkupCode"/> 
      <xsl:for-each select="key('groups', $currentGroup)"> 
       <xsl:copy-of select="../.."/> 
      </xsl:for-each> 
     </MarkupCode> 
    </xsl:template> 

</xsl:stylesheet> 

выпуск что все узлы MarkupTrans_Detail сгруппированы под первым LAC_SalesOrderId, но мне нужно, чтобы они были разделены каждым LAC_SalesOrderId. Я считаю, что я что-то очевидное отсутствует, и надеюсь, что есть кто-то, что может помочь мне понять это :)

ответ

0

Попробуй так:

XSLT 1,0

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/> 
<xsl:strip-space elements="*"/> 

<xsl:key name="grp" match="MarkupTrans_Detail" use="concat(FIELD_MarkupTrans_MarkupCode, '|', generate-id(ancestor::LAC_SalesOrderId))"/> 

<!-- identity transform --> 
<xsl:template match="@*|node()"> 
    <xsl:copy> 
     <xsl:apply-templates select="@*|node()"/> 
    </xsl:copy> 
</xsl:template> 

<xsl:template match="Detail_Collection"> 
    <xsl:copy> 
     <xsl:for-each select="Detail//MarkupTrans_Detail[generate-id() = generate-id(key('grp', concat(FIELD_MarkupTrans_MarkupCode, '|', generate-id(ancestor::LAC_SalesOrderId)))[1])]"> 
      <MarkupCode> 
       <Code> 
        <xsl:value-of select="FIELD_MarkupTrans_MarkupCode"/> 
       </Code> 
       <xsl:apply-templates select="key('grp', concat(FIELD_MarkupTrans_MarkupCode, '|', generate-id(ancestor::LAC_SalesOrderId)))"/>      
      </MarkupCode> 
     </xsl:for-each> 
    </xsl:copy> 
</xsl:template> 

</xsl:stylesheet> 

примененном к вашему введите результат:

<?xml version="1.0" encoding="UTF-8"?> 
<Report> 
    <LAC_SalesOrderId> 
     <APL> 
     <LAC_Customer>09680001</LAC_Customer> 
     </APL> 
     <Detail> 
     <LACRecId_DONOT_CHANGE_Textbox169>5637144820</LACRecId_DONOT_CHANGE_Textbox169> 
     <LAC_MarkupTransLines> 
      <MarkupTrans> 
       <Detail_Collection> 
        <MarkupCode> 
        <Code>Avgift</Code> 
        <MarkupTrans_Detail> 
         <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
         <FIELD_MarkupTrans_Value>10,00</FIELD_MarkupTrans_Value> 
        </MarkupTrans_Detail> 
        <MarkupTrans_Detail> 
         <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
         <FIELD_MarkupTrans_Value>10,00</FIELD_MarkupTrans_Value> 
        </MarkupTrans_Detail> 
        </MarkupCode> 
        <MarkupCode> 
        <Code>Frakt</Code> 
        <MarkupTrans_Detail> 
         <FIELD_MarkupTrans_MarkupCode>Frakt</FIELD_MarkupTrans_MarkupCode> 
         <FIELD_MarkupTrans_Value>10,00</FIELD_MarkupTrans_Value> 
        </MarkupTrans_Detail> 
        </MarkupCode> 
       </Detail_Collection> 
      </MarkupTrans> 
     </LAC_MarkupTransLines> 
     </Detail> 
    </LAC_SalesOrderId> 
    <LAC_SalesOrderId> 
     <APL> 
     <LAC_Customer>09680002</LAC_Customer> 
     </APL> 
     <Detail> 
     <LACRecId_DONOT_CHANGE_Textbox169>5637144821</LACRecId_DONOT_CHANGE_Textbox169> 
     <LAC_MarkupTransLines> 
      <MarkupTrans> 
       <Detail_Collection> 
        <MarkupCode> 
        <Code>Avgift</Code> 
        <MarkupTrans_Detail> 
         <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
         <FIELD_MarkupTrans_Value>20,00</FIELD_MarkupTrans_Value> 
        </MarkupTrans_Detail> 
        <MarkupTrans_Detail> 
         <FIELD_MarkupTrans_MarkupCode>Avgift</FIELD_MarkupTrans_MarkupCode> 
         <FIELD_MarkupTrans_Value>20,00</FIELD_MarkupTrans_Value> 
        </MarkupTrans_Detail> 
        </MarkupCode> 
        <MarkupCode> 
        <Code>Frakt</Code> 
        <MarkupTrans_Detail> 
         <FIELD_MarkupTrans_MarkupCode>Frakt</FIELD_MarkupTrans_MarkupCode> 
         <FIELD_MarkupTrans_Value>30,00</FIELD_MarkupTrans_Value> 
        </MarkupTrans_Detail> 
        </MarkupCode> 
       </Detail_Collection> 
      </MarkupTrans> 
     </LAC_MarkupTransLines> 
     </Detail> 
    </LAC_SalesOrderId> 
</Report> 
+0

Вы дали мне 90% ответа, но я все еще боюсь с последними 10% :(Я бы хотел, чтобы преспер структура, поэтому узел «Detail_Collection» перезаписывается сгруппированными узлами, но сохраняет остальную часть структуры XML. –

Смежные вопросы