以文本方式查看主题

-  中文XML论坛 - 专业的XML技术讨论区  (http://bbs.xml.org.cn/index.asp)
--  『 XML源码及示例(仅原创和转载) 』  (http://bbs.xml.org.cn/list.asp?boardid=32)
----  [转帖]在XSLT实现按日期排序  (http://bbs.xml.org.cn/dispbbs.asp?boardid=32&rootid=&id=5605)


--  作者:admin
--  发布时间:3/9/2004 11:37:00 PM

--  [转帖]在XSLT实现按日期排序
转载自:http://www.csdn.net/Develop/Read_Article.asp?Id=24853

在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>
              <a 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>

查看转换结果
http://sz.luohuedu.net/xml/SortXML.xml
本地演示:http://bbs.xml.org.cn/demo/SortXML.xml

[此贴子已经被作者于2004-3-10 0:51:40编辑过]

--  作者:mimidingdang
--  发布时间:3/10/2004 4:54:00 PM

--  
你好厉害哦,小M佩服佩服!我何时才能到达你这个高度?
W 3 C h i n a ( since 2003 ) 旗 下 站 点
苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
14,156.250ms