如何根据元素条件对提取的值进行排序

Posted

技术标签:

【中文标题】如何根据元素条件对提取的值进行排序【英文标题】:How to sort extracted values according to element conditions 【发布时间】:2014-03-14 02:32:31 【问题描述】:

我有以下 XML 文件:

<?xml version="1.0" encoding="UTF-8"?>
<gbXML xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.gbxml.org/schema xsi.xsd"xmlns="http://www.gbxml.org/schema"
 temperatureUnit="C" lengthUnit="Meters" areaUnit="SquareMeters"volumeUnit="CubicMeters"
useSIUnitsForResults="true" version="0.37">

<Pared id="Pa-1" paredType="Shade">     
<Name>P-S-1</Name>
<Order>
    <Direction>0.000000</Direction>
    <Angle>90.000000</Angle>
    <Height>3.657818</Height>
    <Width>15.200000</Width>
</Order>
</Pared>
<Pared id="Pa-2" paredType="Shade">     
    <Name>P-S-2</Name>
    <Order>
        <Direction>90.000000</Direction>
        <Angle>90.000000</Angle>
        <Height>2.598076</Height>
        <Width>14.200000</Width>
    </Order>
</Pared>
</gbXML>

我想提取每个“Pared id”的“Height”和“Width”值,并根据“Direction”和“Angle”值对它们进行排序。例如,在“Pared id=”Pa-1”中,如果“Direction”= 0.000000 AND “Angle”= 90.000000,那么提取的Width和Height值的顺序应该是:

(Width, 0.00)
(Width, Height)
(0.00, Height)
(0.00, 0.00)

我是 XSLT 的新手,我知道如何选择 Width 和 Height 的值:

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

<xsl:template match= "gb:Pared">
<xsl:value-of select="gb:Order/gb:Height/>

但我不知道如何像我之前提到的那样手动对它们进行排序。如果有人可以帮助我,我将不胜感激。

我想要以下输出(应用我之前提到的条件):

来自 Pared id="Pa-1:

(15.200000, 0.000000)
(15.200000, 3.657818)
(0.000000, 3.657818)
(0.000000, 0.000000)

来自 Pared id="Pa-2:

(0.000000, 0.000000)
(14.200000, 0.000000)
(14.200000, 2.598076)
(0.000000, 2.598076)

将其视为墙坐标 X,Y。两堵墙不能有相同的坐标,并且高度和宽度的值就像坐标值一样。根据墙壁的“方向”和“角度”,这些坐标是如何配对的。 由于描述该墙的 4 个 X、Y 点,您有 0.000 个坐标值。因此,Pa-1 和 Pa-2 不能具有相同的坐标,但它们可能会在一个坐标处连接。比如如果有两堵墙形成L形,0.00, 0.00可以是Pa-1的右下坐标,但如果是Pa-2的情况,0.00, 0.00就是左下坐标。

【问题讨论】:

【参考方案1】:

不确定我是否理解正确。以下 XSL 输出宽度和高度值,按 Pared 部分分组,按 Direction 然后 Angle(数字,升序)排序。

请注意,在您的 XML 示例中,我必须用空格分隔 gbXML 的一些属性(否则它不是有效的 XML)。

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0"
 xmlns:ns0="http://www.gbxml.org/schema">
    <xsl:output method="text" version="1.0" encoding="UTF-8" indent="no" omit-xml-declaration="yes"/>

    <xsl:template match="/">
        <xsl:for-each select='//ns0:Pared' >
            <xsl:sort select=".//ns0:Direction" data-type='number' order="ascending"/>
            <xsl:sort select=".//ns0:Angle"     data-type='number' order="ascending"/>
-- Pared: <xsl:value-of select="@id" />
(<xsl:value-of select=".//ns0:Width" />,0.00)
(<xsl:value-of select=".//ns0:Width" />,<xsl:value-of select=".//ns0:Height" />)
(0.00,<xsl:value-of select=".//ns0:Height" />)
(0.00,0.00)
</xsl:for-each>
    </xsl:template>
</xsl:stylesheet>

给予

-- Pared: Pa-1
(15.200000,0.00)
(15.200000,3.657818)
(0.00,3.657818)
(0.00,0.00)

-- Pared: Pa-2
(14.200000,0.00)
(14.200000,2.598076)
(0.00,2.598076)
(0.00,0.00)

【讨论】:

感谢您的回复。是的,我只复制部分 XML 文件,这就是原因。当我只有两个“Pared”元素时,您的代码才有效。在完整的 XML 文件中,我有更多的“Pared”元素,其中一些具有相同的“Direction”和“Angle”值,但“Height”和“Width”值不同。我没有把我拥有的所有 22 个 Pared 元素都放好,因为我认为理解我想要的东西会非常混乱。你的代码很有帮助,因为我现在有了一个想法,只需要解决我之前提到的问题。再次感谢您!

以上是关于如何根据元素条件对提取的值进行排序的主要内容,如果未能解决你的问题,请参考以下文章

如何获取具有相同名称的元素并根据 XSLT 中的子节点值对它们进行排序

如何同时使用两个功能对 RDD 条目进行排序?

如何对包含空元素的对象数组进行排序?

ReactJS:如何根据道具的值对对象数组进行排序?

如何按名称对具有匹配元素的值进行排序?

在 MongoDB 中,如何根据对象的值对对象进行排序?