在XSLT实现按日期排序

原创 2004年02月26日 14:49:00

在XSLT实现按日期排序


作者:孟宪会 出自:【孟宪会之精彩世界】 发布日期:2004年2月21日 11点47分56秒 


    我们在使用XSLT进行XML转换的时候,经常遇到按XML日期类型的数据进行排序的情况,按照默认的排序规则,很难实现正确的排序效果。虽然最新的MsXML3 SP4提供了3种数据类型的排序方式:

  <xsl:sort 
    
select = string-expression 
    
data-type = { "text" | "number" | Qname }
    order 
= { "ascending" | "descending" } 
  
/>

但好像仍不能满足我们的需要,下面我们就介绍日期类型数据的排序方法。我们的排序方法是基于下面语句的返回值为true的理论的:

<script language="JavaScript">    alert(Date.parse("2004/08/09")==Date.parse("2004/8/9"))  </script>

好了,下面就是我们的xsl文件:

SortXML.xsl

<?xml version="1.0" encoding="gb2312"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
 xmlns:msxsl
="urn:schemas-microsoft-com:xslt" xmlns:user="http://dotnet.aspx.cc/"
 exclude-result-prefixes
="msxsl user">
  
<msxsl:script language="JavaScript" implements-prefix="user">
    function xmlDateTime(nodelist) {
      return Date.parse(nodelist.replace(/-/g,"/"));
    }
  
</msxsl:script>
  
<xsl:output omit-xml-declaration="yes"/>
  
<xsl:template match="/">
    
<xsl:call-template name="ItemList"/>
  
</xsl:template>
  
<xsl:template name="ItemList">
    
<table bgcolor="snow" border="1" cellpadding="5" cellspacing="2" borderColor="darkorange" style="font-size:9pt">
      
<thead>
        
<tr bgcolor="">
          
<th width="50%">标题</th>
          
<th width="50%">修改时间</th>
        
</tr>
      
</thead>
      
<tbody>
        
<xsl:for-each select="/multistatus/response">
          
<xsl:sort order="descending" select="user:xmlDateTime(string(getlastmodified))" data-type="number"/>
          
<tr>
            
<td>
              
<href="{href}" target="_blank">
                
<xsl:value-of select="Title"/>
              
</a>
            
</td>
            
<td>
              
<xsl:value-of select="getlastmodified"/>
            
</td>
          
</tr>
        
</xsl:for-each>
      
</tbody>
    
</table>
  
</xsl:template>
</xsl:stylesheet>

SortXML.xml

<?xml version="1.0" encoding="GB2312"?>
<?xml-stylesheet type="text/xsl" href="SortXML.xsl"?>
<multistatus>
  
<response>
    
<href>http://sz.luohuedu.net/xml/</href>
    
<getlastmodified>2004-8-14 10:51:44</getlastmodified>
    
<Title>【孟宪会之精彩世界】</Title>
  
</response>
  
<response>
    
<href>http://dotnet.aspx.cc/Play.aspx</href>
    
<getlastmodified>2004-10-23 11:11:10</getlastmodified>
    
<Title>【孟宪会之精彩世界】音乐频道</Title>
  
</response>
  
<response>
    
<href>http://dotnet.aspx.cc/</href>
    
<getlastmodified>2004-02-10 18:36:19</getlastmodified>
    
<Title>【孟宪会之精彩世界】</Title>
  
</response>
  
<response>
    
<href>http://lucky.myrice.com/</href>
    
<getlastmodified>2004-01-14 10:51:21</getlastmodified>
    
<Title>【孟宪会之精彩世界】</Title>
  
</response>
  
<response>
    
<href>http://dotnet.aspx.cc/ShowList.aspx&amp;id=1</href>
    
<getlastmodified>2003-11-2 10:52:26</getlastmodified>
    
<Title>【孟宪会之精彩世界】ASP.NET</Title>
  
</response>
  
<response>
    
<href>http://dotnet.aspx.cc/CoolMenu/main.htm</href>
    
<getlastmodified>1999-02-21 22:07:43</getlastmodified>
    
<Title>【孟宪会之精彩世界】DHtml精彩放送</Title>
  
</response>
</multistatus>


XSLT简单教程--XSLT的实例

XSLT如何转换XML我们打个有趣的比方,你玩过橡皮泥吧,用不同的模子按上去,就可以做出需要的形状。如果我们假设XML数据文档是一块大橡皮泥,XSLT就象是一个模子,用力一按,就做出需要的形状来---...
  • guoguo1980
  • guoguo1980
  • 2006年09月14日 11:27
  • 11088

jquery 读取XML 文件 并按时间进行排序

jQuery 读取XML文件,jQuery 按时间进行降序排列
  • aaalk1001
  • aaalk1001
  • 2016年09月21日 13:57
  • 608

在XSLT实现按日期排序

在XSLT实现按日期排序 作者:孟宪会 出自:【孟宪会之精彩世界】 发布日期:2004年2月21日 11点47分56秒     我们在使用XSLT进行XML转换的时候,经常遇到按XML日期类型的数据进...
  • net_lover
  • net_lover
  • 2004年02月26日 14:49
  • 3872

在XSLT实现按日期排序

在XSLT实现按日期排序 作者:孟宪会 出自:【孟宪会之精彩世界】 发布日期:2004年2月21日 11点47分56秒     我们在使用XSLT进行XML转换的时候,经常遇到按XML日期类型的数...
  • hejishan
  • hejishan
  • 2008年03月11日 12:09
  • 280

实现按日期和大小排序 Android

实现按日期和大小排序 Android 摘要:经常看见有人还在不厌其烦的用冒泡(最常见!)或是交换做排序,实际上用几行代码就可以既快又好地实现排序,不论是简单类型还是类,数...
  • linuxcjh
  • linuxcjh
  • 2012年09月08日 11:01
  • 1981

Android 列表按照时间排序

项目中在listview展示历史记录,需求是要按照时间来排序,其实原理很简单,只要将绑定的数据先进行排序,然后放到listview里面填充展示就可以了,解决方案如下:     排序方法如下:     ...
  • omayyouhappy
  • omayyouhappy
  • 2015年08月19日 13:47
  • 4079

对xml文件进行解析+排序+生成文件

  • 2011年07月28日 12:59
  • 5KB
  • 下载

mysql 按月份排序,如果月份相同,按日期排序

select * from 表名 order by date_format(字段名,'%m-%d'); 如果是group by,则同序数据只取id小的那个。...
  • mr_orange_klj
  • mr_orange_klj
  • 2015年01月16日 15:29
  • 1203

先按时间排序,再按姓名排序 sql语句

将字段依次写在order by 后面即可 , 中间用逗号隔开 select * from 表 order by time , name select * from 表 order by time as...
  • yyyyu3
  • yyyyu3
  • 2013年03月22日 10:15
  • 3709

xml排序

1 xsl:sort所使用的名字空间:xmlns:xsl=http://www.w3.org/1999/XSL/TransformSyntaxselect="expression"lang="lang...
  • wqf363
  • wqf363
  • 2007年01月18日 19:21
  • 3386
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在XSLT实现按日期排序
举报原因:
原因补充:

(最多只允许输入30个字)