在muenchian分组中,当我可以直接使用密钥时,为什么要选择generate id



我的输入xml文件如下:

<root>
  <Property>
    <Name>Jack</Name>
    <Color>red.green</Color>    
  </Property>
  <Property>
    <Name>Jill</Name>
    <Color>red.blue</Color>    
  </Property>
  <Property>
    <Name>Jim</Name>
    <Color>red.orange</Color>    
  </Property>
  <Property>
    <Name>Tom</Name>
    <Color>black.brown</Color>    
  </Property>
  .
  .
  . 
  <Property>
    <Name>Tom</Name>
    <Color>white</Color>    
  </Property>
</root>

在XSLT1.0中,我希望选择元素值在前面的所有Property元素。相同,并使之前的值相同。作为一个记录。

示例(使用示例子输入文件)1) input.xml

    <root>
      <Property>
        <Name>Jack</Name>
        <Color>red.green</Color>    
      </Property>
      <Property>
        <Name>Jill</Name>
        <Color>red.blue</Color>    
      </Property>
      <Property>
        <Name>Jim</Name>
        <Color>red.orange</Color>    
      </Property>             
    </root>

样本子输出.xml

<red>
  <green>Jack<green>
  <blue>Jill<blue>
  <orange>Jim<orange>      
<red>

2) input.xml

    <root>
      <Property>
        <Name>Jack</Name>
        <Color>red.green</Color>    
      </Property>
      <Property>
        <Name>Jill</Name>
        <Color>green.orange</Color>    
      </Property>
      <Property>
        <Name>Jim</Name>
        <Color>orange.red</Color>    
      </Property>
      <Property>
        <Name>Ted</Name>
        <Color>brown</Color>    
      </Property>     
    </root>

样本子输出.xml

<red>
  <green>Jack</green>
</red>
<green>
  <orange>Jill<orange> 
</green>   
<orange> 
  <red>Jim</red>
</orange> 
<brown>Ted</brown>

我在stackoverflow中也问过类似的问题,但我对这样的说法感到困惑

<xsl:apply-templates select="/root/Property[generate-id(.) = generate-id(key('test',Property)[1])]"/>

其中密钥为:

<xsl:key name='test' match='Property' use='.'/>

[这里还有一个问题:键的匹配值应该给定为Property或root/Property。我认为键根据上下文选择Property元素。(这里的上下文是/root/Property,因为它是语句<xsl:apply-templates select="/root/Property)中给出的XPATH表达式。这是真的吗?请澄清。]

我真正关心的是

而不是使用这个:

<xsl:apply-templates select="/root/Property[generate-id(.) = generate-id(key('test',Property)[1])]"/>

我可以使用这个:

<xsl:apply-templates select="key('test',//root/Property)"/>

其中密钥是

<xsl:key name='test' match='Property' use='.'/>

实际的区别是什么(在执行和流程方面)?

指令

<xsl:apply-templates select="key('test',//root/Property)"/>

获取所有Property元素,提取它们的值,然后对于每个值,查找具有该值的所有Property元素;则它消除重复;因此,最终结果是通过一条非常冗长的路线找到所有Property元素。

指令

<xsl:apply-templates 
select="/root/Property[generate-id(.) = generate-id(key('test',Property)[1])]"/>

也不正确,除非您的Property元素有名为Property的子元素,这似乎不太可能。我想你打算

<xsl:apply-templates 
select="/root/Property[generate-id(.) = generate-id(key('test',.)[1])]"/>

这样做的目的是,如果Property元素的标识符(generate id)与具有该值的第一个Property元素的标识相同,则选择Property元素。换句话说:对于输入中的每个属性值,都有一组具有该值的property元素,这样做的目的是选择每个组中的第一个元素。

如果您仍然无法理解,请尝试迁移到XSLT2.0,在那里分组变得更加简单。

相关内容

  • 没有找到相关文章

最新更新