Avatar billede nielsen2002 Nybegynder
08. januar 2009 - 10:22 Der er 1 kommentar

Filtrering på Nodes i flere niveauer

Hej Eksperten,

Je har stødt på en lille udfordring som jeg ikke har kunnet gennemskue.

Jeg har noget XML som jeg vha. XSLT gerne vil have formateret lidt så jeg får fjernet nogle Nodes.

Jeg har følgende rå XML:

<Order>
  <Order>
    <OrderID>1000</OrderID>
    <OrderShopID>SHOP2</OrderShopID>
    <OrderDate>10/29/2007 11:14:21 AM</OrderDate>
    <OrderModified>10/29/2007 11:14:21 AM</OrderModified>
    <OrderStepNum>6</OrderStepNum>
    <OrderLines>
      <OrderLine>
        <OrderLineID>OL168</OrderLineID>
        <OrderLineOrderID>CART100</OrderLineOrderID>
        <OrderLineParentLineID />
      </OrderLine>
      <OrderLine>
        <OrderLineID>OL168</OrderLineID>
        <OrderLineOrderID>CART100</OrderLineOrderID>
        <OrderLineParentLineID />
      </OrderLine>
    </OrderLines>
  </Order>
  <Order>
    ....
  </Order>
  ...
</Order>

Jeg ønsker at få fjernet Order/Order/OrderDate noden og Order/Order/OrderLines/OrderLine/OrderLineParentLineID

Lige nu har jeg følgende XSLT som fjerner OrderDate, men jeg er i tvivl om hvordan jeg også får fjernet OrderLineParentLineID.

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
  <xsl:output method="xml" indent="yes"/>
  <!-- Match alt-->
  <xsl:template match="/">
    <Order>
      <xsl:apply-templates select="Order/Order[OrderStepNum = 6]"></xsl:apply-templates>
    </Order>
  </xsl:template>
  <xsl:template match="Order/Order[OrderStepNum = 6]">
    <xsl:copy-of select="*[not(self::OrderDate)]"/>
  </xsl:template>
</xsl:stylesheet>

XMLen er forsimplet, så vil ikke hardcode alle noder på nær dem jeg ikke vil have med.

Kan Nogen som kan hjælpe :)

/Martin
Avatar billede jokkejensen Novice
09. januar 2009 - 12:10 #1
Hej Martin.

Ofte er det letteste at tegne xmlen på ny, altså bruge dit gamle som kilde, og ellers bruge en template til at hente data og designe på ny..

ex:


xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
    <xsl:output method="xml" indent="yes"/>
    <!-- Match alt-->
    <xsl:template match="/">
        <Orders>
            <xsl:apply-templates select="Order/Order"></xsl:apply-templates>
        </Orders>
    </xsl:template>
    <xsl:template match="Order">
        <Order>
            <ID>
                <xsl:value-of select="OrderID"/>
            </ID>
            <OrdrerLinier>
                <xsl:copy-of select=".//OrderLine"/>
            </OrdrerLinier>
        </Order>
    </xsl:template>
</xsl:stylesheet>

Den skulle gerne danne en liste ala:

<Orders>
<!-- For hver ordre -->
<Order>
<ID></ID>
<OrdrerLinier>
.......
</OrdrerLinier>
<!-- #For hver ordre -->
</Order>
</Orders>

På den måde kan du frit opsætte som du ønsker. Det er straks værre når man ikke kender input.

/J
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester