в XPath даты сравнения

Я пытаюсь фильтровать элементы на основе атрибута, который является датой в формате 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 to работа? Возможно, пространство имен xs: определение?

2 ответов


в 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"/>

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

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