0
我正尝试按两个字段之一排序XML节点集,条件是另一个字段中的值。按两个字段中的一个进行排序
<xsl:for-each select="CampusCourseDeliveryItem">
<xsl:sort select="OffCampus"/>
<xsl:sort select="OrganisationName" />
<xsl:sort select="OffCampusLocation"/>
<!-- code to display node goes here -->
我想,如果OffCampus='Y'
,使用OffCampusLocation
作为排序关键字,否则使用OrganisationName
。
示例数据:
<CampusCourseDelivery>
<CampusCourseDeliveryItem>
<OrganisationName>Chicago</OrganisationName>
<OffCampus>N</OffCampus>
<OffCampusLocation></OffCampusLocation>
</CampusCourseDeliveryItem>
<CampusCourseDeliveryItem>
<OrganisationName>London</OrganisationName>
<OffCampus>Y</OffCampus>
<OffCampusLocation>Detroit</OffCampusLocation>
</CampusCourseDeliveryItem>
<CampusCourseDeliveryItem>
<OrganisationName>Seattle</OrganisationName>
<OffCampus>Y</OffCampus>
<OffCampusLocation>Berlin</OffCampusLocation>
</CampusCourseDeliveryItem>
<CampusCourseDeliveryItem>
<OrganisationName>Adelaide</OrganisationName>
<OffCampus>N</OffCampus>
<OffCampusLocation>Ignore this value</OffCampusLocation>
</CampusCourseDeliveryItem>
</CampusCourseDelivery>
预期排序顺序:
Adelaide
Berlin
Chicago
Detroit
这几乎是* *工作...我不得不改变' OffCampus ='N''到'normalize-space(OffCampus)!='Y''来处理OffCampus为空的情况。 (在我的示例数据中,我没有举一个例子,所以你没有照顾它。) – Adeptus 2014-10-27 01:37:05