Oprettet tir. d. 04. maj 2010 kl. 17:37:20

filix
filix (9.095 point. Point ude: 255)

Hvordan kan jeg se om en dato er imellem 2 datoer ?

Hej

Hvordan kan jeg se om 1 dato er imellem 2 datoer?

Jeg har et søge resultat der skal formateres, så man kan indtaste 2 datoer også få alle poster imellem.

Men kan man gøre dette i xslt 1,0 ?

Skrevet søn. d. 09. maj 2010 kl. 03:55:24| #1

arne_v
arne_v (1.005.623 point)
Hvis felterne indeholder en xsd:date, så er alfabetisk sammenligning jo identisk med tidsmæssig sammenligning, således at helt normal < kan anvendes.

Skrevet søn. d. 09. maj 2010 kl. 10:01:25| #2

filix
filix (9.095 point)
Hejsa Arne

Det er jo kun i Schemas det kan benyttes(som jeg mener det), og her skal jeg benytte det i xsl 1.0.

jeg har en dato stående i xml som ser sådan ud  <Row.Value>08-02-1917</Row.Value>

også har jeg de 2 værdier her
<Server.Request.qstart>06-13-1927</Server.Request.qstart>
  <Server.Request.qend>06-27-1927</Server.Request.qend>

og jeg synes ikke at kunne få normale identifiers til at virke.

Jeg ved ikke om jeg kan kaste værdierne til at virke ?

Skrevet ons. d. 12. maj 2010 kl. 16:22:32| #3

jokkejensen
jokkejensen (36.240 point)
Det skal gøres gennem en xslt extension, eller også bliver det tricky..

Det kan evt klares inline med C#, men kender ikke dit miljø :

    xmlns:date="ffs"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt"

<msxsl:script implements-prefix="date" language="C#">
        public XPathNodeIterator GetNodes(XPathNodeIterator node, string DateStart, string DateEnd)
        {
       
// kode som Arne nemt kan skrive :)
}
    </msxsl:script>

<xsl:variable name="GyldigeNodes" select="msxml:node-set(date:GetNodes($noder, 'xx-xx-xxxx', 'xx-xx-xxxx'))" />


Skal det gøres gennem xslt alene, kræver det at du omskriver datoen..

Ex

<xsl:variable name="gammelXML">
<data>
<node dato="12-12-2001"/>
<node dato="12-08-1998"/>
</data>
</xsl:variable>

<xsl:variable name="nyXML">
<data>
<xsl:foreach select="msxml:node-set($gammelXML)//node">
<xsl:element name="node">
<xsl:attribute name="dato">
<xsl:value-of select="concat(substring-after(substring-after(@dato, '-'), '-'), substring-before(substring-after(@dato, '-'), '-'), substring-before(@dato, '-'))" />
</xsl:attribute>
</xsl:element>
</xsl:foreach>
</data>
</xsl:variable>

Det skulle gerne vende datoen om til noget mere fornuftigt at søge efter ala:

<node dato="20011212" />
<node dato="19980812" />

Det er ikke lige testet, men det er fremgangsmåden.

Jeg foretrækker selv at løse gennem xslt extensions, lader til at performe bedre.

/J

Skrevet ons. d. 12. maj 2010 kl. 17:13:25| #4

arne_v
arne_v (1.005.623 point)
Jeg ville hellere skifte formatet til standard formatet, så er det nemt at sammenligne - og det som viser XML kan så vende formatet til det ønskede UI format.

Skrevet ons. d. 12. maj 2010 kl. 17:17:06| #5

jokkejensen
jokkejensen (36.240 point)
ja XMLdates er at foretrække i xml. lette at sammenligne med mm.

Ofte er datagrundlaget bare ikke så let at rokke ved, der er sikkert en grund til han ikke blot har ændret.

/J

Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Benytte XSLT til tranformering af data imellem 2 systemer

Oprettet den 8. december 2011 kl. 11.52
bongo13 giver 60 point for svar | Giv et svar »

fo:block kollapser

Oprettet den 14. november 2011 kl. 11.16
schristensen giver 200 point for svar | Giv et svar »

Select i Xpath, ignorere case

Oprettet den 20. oktober 2011 kl. 00.01
wise giver 30 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger