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