Сравнение дат 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: namespace определение?
Ответы
Ответ 1
В обоих 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"/>
Ответ 2
<cfset startdatetime = Now() >
<cfset nNow = LSParseNumber(DateFormat(DateAdd('n', -15,startdatetime),'yyyyMMddHHmm')) >
number(substring(concat(translate(text(),'-: ',''),'0000000000000000'),1,12))<=#nNow#