How to find index position for group line item in xsl

自作多情 提交于 2019-12-24 10:27:13

问题


Could anyone help me?

Input XML:

<dataXML>
<Items>
    <itemLine>
        <lineNo>1</lineNo>
        <lineRefNo>001</lineRefNo>
        <lineDes>test1</lineDes>
    </itemLine>
    <itemLine>
        <lineNo>6</lineNo>
        <lineRefNo>003</lineRefNo>
        <lineDes>test6</lineDes>
    </itemLine>
    <itemLine>
        <lineNo>4</lineNo>
        <lineRefNo>002</lineRefNo>
        <lineDes>test4</lineDes>
    </itemLine>
    <itemLine>    
        <lineNo>3</lineNo>
        <lineRefNo>002</lineRefNo>
        <lineDes>test3</lineDes>
    </itemLine>   
    <itemLine>
            <lineNo>7</lineNo>
            <lineRefNo>003</lineRefNo>
            <lineDes>test7</lineDes>    
        </itemLine>         
    <itemLine>
        <lineNo>5</lineNo>
        <lineRefNo>002</lineRefNo>
        <lineDes>test5</lineDes>
    </itemLine>    
    <itemLine>
        <lineNo>2</lineNo>
        <lineRefNo>001</lineRefNo>
        <lineDes>test2</lineDes>
    </itemLine>
</Items>
</dataXML>

Need to group item lines based on LineRefNo for index position.

Expected Result: Natural order must be same.

<dataXML>
    <Items>
        <itemLine>
            <lineNo>1</lineNo>
            <lineRefNo>001</lineRefNo>
            <lineDes>test1</lineDes>
            <RefNoIndex>1</RefNoIndex>
        </itemLine>
        <itemLine>
            <lineNo>6</lineNo>
            <lineRefNo>003</lineRefNo>
            <lineDes>test6</lineDes>
            <RefNoIndex>1</RefNoIndex>
        </itemLine>
        <itemLine>
            <lineNo>4</lineNo>
            <lineRefNo>002</lineRefNo>
            <lineDes>test4</lineDes>
            <RefNoIndex>1</RefNoIndex>
        </itemLine>
        <itemLine>    
            <lineNo>3</lineNo>
            <lineRefNo>002</lineRefNo>
            <lineDes>test3</lineDes>
            <RefNoIndex>2</RefNoIndex>
        </itemLine> 
        <itemLine>
            <lineNo>7</lineNo>
            <lineRefNo>003</lineRefNo>
            <lineDes>test7</lineDes>
            <RefNoIndex>2</RefNoIndex>
        </itemLine>         
        <itemLine>
            <lineNo>5</lineNo>
            <lineRefNo>002</lineRefNo>
            <lineDes>test5</lineDes>
            <RefNoIndex>3</RefNoIndex>
        </itemLine>    
        <itemLine>
            <lineNo>2</lineNo>
            <lineRefNo>001</lineRefNo>
            <lineDes>test2</lineDes>
            <RefNoIndex>2</RefNoIndex>
        </itemLine>
    </Items>
    </dataXML>

How to transfer input data using xsl version 1.0?

Thanks in advance.


回答1:


This transformation:

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

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

 <xsl:template match="itemLine/*[last()]">
  <xsl:call-template name="identity"/>

  <RefNoIndex>
   <xsl:copy-of select=
   "count(preceding::lineRefNo[. = current()/../lineRefNo])"/>
  </RefNoIndex>
 </xsl:template>
</xsl:stylesheet>

when applied on the provided XML document:

<dataXML>
    <Items>
        <itemLine>
            <lineNo>1</lineNo>
            <lineRefNo>001</lineRefNo>
            <lineDes>test1</lineDes>
        </itemLine>
        <itemLine>
            <lineNo>6</lineNo>
            <lineRefNo>003</lineRefNo>
            <lineDes>test6</lineDes>
        </itemLine>
        <itemLine>
            <lineNo>4</lineNo>
            <lineRefNo>002</lineRefNo>
            <lineDes>test4</lineDes>
        </itemLine>
        <itemLine>
            <lineNo>3</lineNo>
            <lineRefNo>002</lineRefNo>
            <lineDes>test3</lineDes>
        </itemLine>
        <itemLine>
            <lineNo>7</lineNo>
            <lineRefNo>003</lineRefNo>
            <lineDes>test7</lineDes>
        </itemLine>
        <itemLine>
            <lineNo>5</lineNo>
            <lineRefNo>002</lineRefNo>
            <lineDes>test5</lineDes>
        </itemLine>
        <itemLine>
            <lineNo>2</lineNo>
            <lineRefNo>001</lineRefNo>
            <lineDes>test2</lineDes>
        </itemLine>
    </Items>
</dataXML>

produces the wanted, correct result:

<dataXML>
   <Items>
      <itemLine>
         <lineNo>1</lineNo>
         <lineRefNo>001</lineRefNo>
         <lineDes>test1</lineDes>
         <RefNoIndex>1</RefNoIndex>
      </itemLine>
      <itemLine>
         <lineNo>6</lineNo>
         <lineRefNo>003</lineRefNo>
         <lineDes>test6</lineDes>
         <RefNoIndex>1</RefNoIndex>
      </itemLine>
      <itemLine>
         <lineNo>4</lineNo>
         <lineRefNo>002</lineRefNo>
         <lineDes>test4</lineDes>
         <RefNoIndex>1</RefNoIndex>
      </itemLine>
      <itemLine>
         <lineNo>3</lineNo>
         <lineRefNo>002</lineRefNo>
         <lineDes>test3</lineDes>
         <RefNoIndex>2</RefNoIndex>
      </itemLine>
      <itemLine>
         <lineNo>7</lineNo>
         <lineRefNo>003</lineRefNo>
         <lineDes>test7</lineDes>
         <RefNoIndex>2</RefNoIndex>
      </itemLine>
      <itemLine>
         <lineNo>5</lineNo>
         <lineRefNo>002</lineRefNo>
         <lineDes>test5</lineDes>
         <RefNoIndex>3</RefNoIndex>
      </itemLine>
      <itemLine>
         <lineNo>2</lineNo>
         <lineRefNo>001</lineRefNo>
         <lineDes>test2</lineDes>
         <RefNoIndex>2</RefNoIndex>
      </itemLine>
   </Items>
</dataXML>


来源:https://stackoverflow.com/questions/9546085/how-to-find-index-position-for-group-line-item-in-xsl

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!