Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/xslt/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Xml 基于条件考虑多个节点的XSLT密钥分组_Xml_Xslt_Xslt Grouping_Xslkey - Fatal编程技术网

Xml 基于条件考虑多个节点的XSLT密钥分组

Xml 基于条件考虑多个节点的XSLT密钥分组,xml,xslt,xslt-grouping,xslkey,Xml,Xslt,Xslt Grouping,Xslkey,我有这个输入XML,它是我的XML的延续。基本上,我希望根据节点的值对节点进行分组。映射如下: <xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output method="xml" version="1.0" encoding="UTF-8" ind

我有这个输入XML,它是我的XML的延续。基本上,我希望根据
节点的值对节点进行分组。映射如下:

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

<xsl:key name="entry" match="Entry" use="Details/Code"/>

<xsl:template match="/root">
    <Output>
        <Code-group> A </Code-group>
        <Sum>
            <xsl:value-of select="sum(key('entry', ('A1', 'A2', 'A3'))/Details/Value)" />
        </Sum>
        <Code-group> B </Code-group>
        <Sum>
            <xsl:value-of select="sum(key('entry', ('B1', 'B2', 'B3'))/Details/Value)" />
        </Sum>
    </Output>
</xsl:template>

</xsl:stylesheet>
  • 代码“A1”、“A2”和“A3”需要分组在一起(比如代码组“A”)
  • 代码“B1”、“B2”和“B3”需要组合在一起(假设代码组“B”)
  • 这些代码是通用的,只是作为例子,实际代码是不同的,不是很简单,请不要考虑字面上的“< /P>”。 我最终对这些组中

    节点的值进行求和,但除了我前面的问题,我仅在
    节点值大于或等于2时进行求和

    我目前使用这个XSLT(credits:michael.hor257k):

    
    A.
    B
    
    它产生如下输出:

    <xsl:stylesheet version="2.0" 
       xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
    
    <xsl:key name="entry" match="Entry" use="Details/Code"/>
    
    <xsl:template match="/root">
        <Output>
            <Code-group> A </Code-group>
            <Sum>
                <xsl:value-of select="sum(key('entry', ('A1', 'A2', 'A3'))/Details/Value)" />
            </Sum>
            <Code-group> B </Code-group>
            <Sum>
                <xsl:value-of select="sum(key('entry', ('B1', 'B2', 'B3'))/Details/Value)" />
            </Sum>
        </Output>
    </xsl:template>
    
    </xsl:stylesheet>
    
    
    A.
    5500
    B
    11500
    
    但是我需要这个场景的输出:

    <Output>
      <Code-group> A </Code-group>
      <Sum> 5500 </Sum>
    
      <Code-group> B </Code-group>
      <Sum> 11500 </Sum>
    </Output>
    
    
    A.
    4500
    B
    8500
    
    也就是说,只有当
    大于或等于
    2

    在定义键时是否有方法包含此关系运算符,还是应将其实现为2个键?感谢您的任何意见


    提前谢谢

    只需使用XPath谓词即可

    <Output>
      <Code-group> A </Code-group>
      <Sum> 4500 </Sum>
    
      <Code-group> B </Code-group>
      <Sum> 8500 </Sum>
    </Output>
    
    
    A.
    B
    
    只需使用XPath谓词

    <Output>
      <Code-group> A </Code-group>
      <Sum> 4500 </Sum>
    
      <Code-group> B </Code-group>
      <Sum> 8500 </Sum>
    </Output>
    
    
    A.
    B
    
    您似乎只需要一个小的修改:

    XSLT2.0

    <xsl:template match="/root">
        <Output>
            <Code-group> A </Code-group>
            <Sum>
                <xsl:value-of select="sum(key('entry', ('A1', 'A2', 'A3'))/Details[Indicator >= 2 ]/Value)" />
            </Sum>
            <Code-group> B </Code-group>
            <Sum>
                <xsl:value-of select="sum(key('entry', ('B1', 'B2', 'B3'))/Details[Indicator >= 2 ]/Value)" />
            </Sum>
        </Output>
    </xsl:template>
    
    
    A.
    B
    
    您似乎只需要一个小的修改:

    XSLT2.0

    <xsl:template match="/root">
        <Output>
            <Code-group> A </Code-group>
            <Sum>
                <xsl:value-of select="sum(key('entry', ('A1', 'A2', 'A3'))/Details[Indicator >= 2 ]/Value)" />
            </Sum>
            <Code-group> B </Code-group>
            <Sum>
                <xsl:value-of select="sum(key('entry', ('B1', 'B2', 'B3'))/Details[Indicator >= 2 ]/Value)" />
            </Sum>
        </Output>
    </xsl:template>
    
    
    A.
    B