Как мы проверяем, находится ли дата в пределах 180 дней от сегодняшнего дня в xslt в datapower

Я пишу xslt для datapower, и в нем я получаю дату (дата платежа). Я должен проверить, находится ли эта дата (дата платежа) в пределах 180 дней от текущей даты.

Я получаю текущую дату следующим

<xsl:variable name="timestamp" select="date:date-time()"/>

Теперь как проверить состояние на 180 дней

Ниже мой xslt

<?xml version="1.0" encoding="utf-8"?>

<xsl:stylesheet version="1.0"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:dp="http://www.datapower.com/extensions"
    xmlns:date="http://exslt.org/dates-and-times"
    xmlns:dpconfig="http://www.datapower.com/param/config"
    extension-element-prefixes="dp"
    exclude-result-prefixes="dp dpconfig"
>

  <xsl:output method="xml"/>

  <xsl:template match="/">
<PaymentDate><xsl:value-of select="dp:http-request-header('X-payment-date')"/></PaymentDate>  (From request I am getting payment date)

<xsl:variable name="timestamp" select="date:date-time()"/>        (From here I am getting present date)

<xsl:if  (this is what I am confused)

Спасибо


person Uselesssss    schedule 13.03.2014    source источник
comment
Откуда вы берете дату, которая должна быть в пределах 180 дней? Пожалуйста, измените свой вопрос, чтобы 1 включить ввод XML, 2 опубликовать полную таблицу стилей XSLT и 3 объяснить, как вы ожидаете, что результат будет выглядеть.   -  person Mathias Müller    schedule 13.03.2014


Ответы (3)


Расчет разницы дат в XSLT 1.0:

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:date="http://exslt.org/dates-and-times"
extension-element-prefixes="date">

<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>

<xsl:template match="/">
    <output>
        <difference>
            <xsl:call-template name="date-difference">
                <xsl:with-param name="date1" select="input/originalDate" />
                <xsl:with-param name="date2" select="date:date-time()" />
            </xsl:call-template>
        </difference>
    </output>
</xsl:template> 

<xsl:template name="date-difference">
    <xsl:param name="date1"/>
    <xsl:param name="date2"/>
    <xsl:param name="JDN1">
        <xsl:call-template name="JDN">
            <xsl:with-param name="date" select="$date1" />
        </xsl:call-template>
    </xsl:param>
    <xsl:param name="JDN2">
        <xsl:call-template name="JDN">
            <xsl:with-param name="date" select="$date2" />
        </xsl:call-template>
    </xsl:param>
    <xsl:value-of select="$JDN2 - $JDN1"/>
</xsl:template> 

<xsl:template name="JDN">
    <xsl:param name="date"/>
    <xsl:param name="year" select="substring($date, 1, 4)"/>
    <xsl:param name="month" select="substring($date, 6, 2)"/>
    <xsl:param name="day" select="substring($date, 9, 2)"/>
    <xsl:param name="a" select="floor((14 - $month) div 12)"/>
    <xsl:param name="y" select="$year + 4800 - $a"/>
    <xsl:param name="m" select="$month + 12*$a - 3"/>
    <xsl:value-of select="$day + floor((153*$m + 2) div 5) + 365*$y + floor($y div 4) - floor($y div 100) + floor($y div 400) - 32045" />
</xsl:template> 

</xsl:stylesheet>

Применительно к следующему входному XML:

<input>
    <originalDate>2013-09-15</originalDate>
</input>

Результат будет:

<?xml version="1.0" encoding="UTF-8"?>
<output>
  <difference>179</difference>
</output>

если преобразование выполняется сегодня, 13 марта 2014 г.

person michael.hor257k    schedule 13.03.2014
comment
этот ответ избавил меня от головной боли!! не могу проголосовать достаточно - person morgan121; 16.05.2019

IBM Datapower предоставляет расширение существующей функции EXSLT. Существует функция под названием «разница» со следующей подписью.

разница() Возвращает продолжительность между первой датой и второй датой. Дата синтаксиса: разница (начало-дата-время, окончание-дата-время)

Вы можете использовать эту функцию, чтобы узнать разницу в датах. Для получения дополнительной информации о функции расширения, доступной в datapower, см. ссылку ниже. Перейдите к главе 5 и найдите функции для управления датой и временем.

http://pic.dhe.ibm.com/infocenter/wsdatap/v3r8m1/topic/xm70/ExtensionFunctions.pdf

-Аджитабх

person Ajitabh Sharma    schedule 14.03.2014

DataPower поддерживает дату: разницу

разница()

Возвращает продолжительность между первой датой и второй датой. Синтаксис

дата: разница (начало-дата-время, окончание-дата-время)

Вы можете передать текущую дату как end-DateTime , дату, которую нужно проверить как start-DateTime

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema" exclude-result-prefixes="xs"
xmlns:date="http://exslt.org/dates-and-times" version="1.0">
<!--<xsl:key name="lang" match="element" use="@language"></xsl:key>-->
<xsl:template match="/">
    <xsl:variable name="date1" select="date:date-time()"/>
    <xsl:variable name="date2" select="'2013-09-15'"/>
    <output>
        <difference>
    <xsl:value-of select="translate(date:difference($date2, $date1),'PD','')"/>
        </difference>
    </output>
</xsl:template>
</xsl:stylesheet>
person Community    schedule 19.06.2014