相关疑难解决方法(0)

与 xsl:sort 一起使用前置兄弟

我正在尝试将前同级和后同级与记录的子集一起使用,并对其进行排序。前面/后面从原来的xml顺序带回值的问题:

<Salaries>
    <Salary>
        <Base>1000</Base>
        <CreatedDate xmlns:d7p1="http://schemas.datacontract.org/2004/07/System">
            <d7p1:DateTime>2016-01-09T14:38:54.8440764Z</d7p1:DateTime>
            <d7p1:OffsetMinutes>0</d7p1:OffsetMinutes>
        </CreatedDate>
    </Salary>
    <Salary>
        <Base>2000</Base>
        <CreatedDate xmlns:d7p1="http://schemas.datacontract.org/2004/07/System">
            <d7p1:DateTime>2015-01-09T14:38:54.8440764Z</d7p1:DateTime>
            <d7p1:OffsetMinutes>0</d7p1:OffsetMinutes>
        </CreatedDate>
    </Salary>
    <Salary>
        <Base>3000</Base>
        <CreatedDate xmlns:d7p1="http://schemas.datacontract.org/2004/07/System">
            <d7p1:DateTime>2017-01-09T14:38:54.8440764Z</d7p1:DateTime>
            <d7p1:OffsetMinutes>0</d7p1:OffsetMinutes>
        </CreatedDate>
    </Salary>
</Salaries>
Run Code Online (Sandbox Code Playgroud)

当我使用带有 ac# 函数的 for-each (Salaries/Salary) 下的排序将偏移分钟添加到日期中并转换为长数 201701010000 例如(以使 xslt 中的操作更容易)。

<xsl:sort select="number(cs:Convertdatetolong(cs:AddOffsetMinutes(substring(p:CreatedDate/d5p1:DateTime,1,19),p:CreatedDate/d5p1:OffsetMinutes)))" order="ascending"/>
Run Code Online (Sandbox Code Playgroud)

排序工作完美,我按以下顺序获取记录:

  • 2000年
  • 1000
  • 3000

如果我使用前兄弟/前(和后),问题就会出现。我希望第一条记录 (2000) 没有前面的记录,最后一条记录 (3000) 没有后续记录。但是,当我使用前/后时,我从原始 XML 中获取上一条记录和下一条记录:

  • 2000(前 - 1000 / 后 - 3000)
  • 1000(之前 - / 之后 - 2000)
  • 3000(前 - 2000 / 后 - )

我希望能够与之前的记录(按排序顺序)和当前记录(按排序顺序)进行比较:

  • 2000(前 - / 后 - 1000)
  • 1000(前 - …

sorting xslt

3
推荐指数
1
解决办法
949
查看次数

标签 统计

sorting ×1

xslt ×1