в 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#