xpath日期比较

时间:2010-12-03 16:00:14

标签: xml xpath xpath-2.0

我正在尝试根据yyyy-MM-dd格式的日期属性过滤元素。

我的XML看起来像这样:

<?xml version="1.0" encoding="utf-8"?>
<root>
  <article title="wired" pub-date="2010-11-22" />
  <article title="Plus 24" pub-date="2010-11-22" />
  <article title="Finance" pub-date="2010-10-25" />
</root>

我的xpath尝试:

'//article[xs:date(./@pub-date) > xs:date("2010-11-15")]'

使用xpath 2.0 - 除非绝对必要,否则将避免添加架构。

来自评论

  

我相信我一定会遗漏一些东西   然后。我有可能需要吗?   为xs:date指定其他内容   工作?也许是xs:namespace   定义

2 个答案:

答案 0 :(得分:29)

在XPath 1.0和2.0中都可以使用

//article[number(translate(@pub-date,'-','')) > 20101115]

您的XPath 2.0表达式是正确的,使用Saxon 9.0.3进行此转换

<xsl:stylesheet version="2.0"
 xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:xs="http://www.w3.org/2001/XMLSchema">

    <xsl:template match="/">
      <xsl:sequence select="//article[xs:date(./@pub-date) > xs:date('2010-11-15')]"/>
    </xsl:template>
</xsl:stylesheet>

应用于提供的XML文档

<root>
  <article title="wired" pub-date="2010-11-22" />
  <article title="Plus 24" pub-date="2010-11-22" />
  <article title="Finance" pub-date="2010-10-25" />
</root>

生成想要的正确结果

<article title="wired" pub-date="2010-11-22"/>
<article title="Plus 24" pub-date="2010-11-22"/>

答案 1 :(得分:2)

<cfset startdatetime = Now() >
<cfset nNow = LSParseNumber(DateFormat(DateAdd('n', -15,startdatetime),'yyyyMMddHHmm')) >

number(substring(concat(translate(text(),'-: ',''),'0000000000000000'),1,12))<=#nNow#