我正在尝试将前同级和后同级与记录的子集一起使用,并对其进行排序。前面/后面从原来的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) 没有前面的记录,最后一条记录 (3000) 没有后续记录。但是,当我使用前/后时,我从原始 XML 中获取上一条记录和下一条记录:
我希望能够与之前的记录(按排序顺序)和当前记录(按排序顺序)进行比较: