We are trying to write XML file using data integration tool (talend) ) then,We triggered tXSLT (that is transformation component) over outputted XML. Basically, we want to apply two transformation at a time. that is
splitting of XML file and removal of xsi:nil ="true" element from our XML document.
Original XML file Look like
It has SalesOrders information
<?xml version="1.0" encoding="Windows-1252"?>
<SalesOrders xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="xmlfilename.xsd">
<Orders>
<OrderHeader>
<CustomerPoNumber>22195175</CustomerPoNumber>
<OrderActionType>A</OrderActionType>
<NewCustomerPoNumber xsi:nil="true"></NewCustomerPoNumber>
<Supplier xsi:nil="true"></Supplier>
<Customer>027885</Customer>
<OrderDate>2016-02-12</OrderDate>
<InvoiceTerms xsi:nil="true"></InvoiceTerms>
<Currency xsi:nil="true"></Currency>
<ShippingInstrs xsi:nil="true"></ShippingInstrs>
<CustomerName>STAGE STORES DIST CTR 00601</CustomerName>
<ShipAddress1 xsi:nil="true"></ShipAddress1>
<ShipAddress2 xsi:nil="true"></ShipAddress2>
<ShipAddress3 xsi:nil="true"></ShipAddress3>
<ShipAddress4 xsi:nil="true"></ShipAddress4>
<ShipAddress5 xsi:nil="true"></ShipAddress5>
<ShipPostalCode xsi:nil="true"></ShipPostalCode>
<Email xsi:nil="true"></Email>
<OrderDiscPercent1 xsi:nil="true"></OrderDiscPercent1>
<OrderDiscPercent2 xsi:nil="true"></OrderDiscPercent2>
<OrderDiscPercent3 xsi:nil="true"></OrderDiscPercent3>
<Warehouse xsi:nil="true"></Warehouse>
<SpecialInstrs xsi:nil="true"></SpecialInstrs>
<SalesOrder xsi:nil="true"></SalesOrder>
<OrderType xsi:nil="true"></OrderType>
<MultiShipCode xsi:nil="true"></MultiShipCode>
<ShipAddressPerLine xsi:nil="true"></ShipAddressPerLine>
<AlternateReference xsi:nil="true"></AlternateReference>
<Salesperson xsi:nil="true"></Salesperson>
<Branch xsi:nil="true"></Branch>
<Area xsi:nil="true"></Area>
<RequestedShipDate xsi:nil="true"></RequestedShipDate>
<InvoiceNumberEntered xsi:nil="true"></InvoiceNumberEntered>
<InvoiceDateEntered xsi:nil="true"></InvoiceDateEntered>
<OrderComments xsi:nil="true"></OrderComments>
<Nationality xsi:nil="true"></Nationality>
<DeliveryTerms xsi:nil="true"></DeliveryTerms>
<TransactionNature xsi:nil="true"></TransactionNature>
<TransportMode xsi:nil="true"></TransportMode>
<ProcessFlag xsi:nil="true"></ProcessFlag>
<TaxExemptNumber xsi:nil="true"></TaxExemptNumber>
<TaxExemptionStatus xsi:nil="true"></TaxExemptionStatus>
<GstExemptNumber xsi:nil="true"></GstExemptNumber>
<GstExemptionStatus xsi:nil="true"></GstExemptionStatus>
<CompanyTaxNumber xsi:nil="true"></CompanyTaxNumber>
<CancelReasonCode xsi:nil="true"></CancelReasonCode>
<DocumentFormat xsi:nil="true"></DocumentFormat>
<State xsi:nil="true"></State>
<CountyZip xsi:nil="true"></CountyZip>
<City xsi:nil="true"></City>
<InvoiceWholeOrderOnly xsi:nil="true"></InvoiceWholeOrderOnly>
<SalesOrderPromoQualifyAction xsi:nil="true"></SalesOrderPromoQualifyAction>
<SalesOrderPromoSelectAction xsi:nil="true"></SalesOrderPromoSelectAction>
<GlobalTradePromotionCodes xsi:nil="true"></GlobalTradePromotionCodes>
<eSignature xsi:nil="true"></eSignature>
<SalesForceOrderNumber>ORD-380804</SalesForceOrderNumber>
</OrderHeader>
<OrderHeader>
<CustomerPoNumber>22195175</CustomerPoNumber>
<OrderActionType>A</OrderActionType>
<NewCustomerPoNumber xsi:nil="true"></NewCustomerPoNumber>
<Supplier xsi:nil="true"></Supplier>
<Customer>027885</Customer>
<OrderDate>2016-02-12</OrderDate>
<InvoiceTerms xsi:nil="true"></InvoiceTerms>
<Currency xsi:nil="true"></Currency>
<ShippingInstrs xsi:nil="true"></ShippingInstrs>
<CustomerName>STAGE STORES DIST CTR 00601</CustomerName>
<ShipAddress1 xsi:nil="true"></ShipAddress1>
<ShipAddress2 xsi:nil="true"></ShipAddress2>
<ShipAddress3 xsi:nil="true"></ShipAddress3>
<ShipAddress4 xsi:nil="true"></ShipAddress4>
<ShipAddress5 xsi:nil="true"></ShipAddress5>
<ShipPostalCode xsi:nil="true"></ShipPostalCode>
<Email xsi:nil="true"></Email>
<OrderDiscPercent1 xsi:nil="true"></OrderDiscPercent1>
<OrderDiscPercent2 xsi:nil="true"></OrderDiscPercent2>
<OrderDiscPercent3 xsi:nil="true"></OrderDiscPercent3>
<Warehouse xsi:nil="true"></Warehouse>
<SpecialInstrs xsi:nil="true"></SpecialInstrs>
<SalesOrder xsi:nil="true"></SalesOrder>
<OrderType xsi:nil="true"></OrderType>
<MultiShipCode xsi:nil="true"></MultiShipCode>
<ShipAddressPerLine xsi:nil="true"></ShipAddressPerLine>
<AlternateReference xsi:nil="true"></AlternateReference>
<Salesperson xsi:nil="true"></Salesperson>
<Branch xsi:nil="true"></Branch>
<Area xsi:nil="true"></Area>
<RequestedShipDate xsi:nil="true"></RequestedShipDate>
<InvoiceNumberEntered xsi:nil="true"></InvoiceNumberEntered>
<InvoiceDateEntered xsi:nil="true"></InvoiceDateEntered>
<OrderComments xsi:nil="true"></OrderComments>
<Nationality xsi:nil="true"></Nationality>
<DeliveryTerms xsi:nil="true"></DeliveryTerms>
<TransactionNature xsi:nil="true"></TransactionNature>
<TransportMode xsi:nil="true"></TransportMode>
<ProcessFlag xsi:nil="true"></ProcessFlag>
<TaxExemptNumber xsi:nil="true"></TaxExemptNumber>
<TaxExemptionStatus xsi:nil="true"></TaxExemptionStatus>
<GstExemptNumber xsi:nil="true"></GstExemptNumber>
<GstExemptionStatus xsi:nil="true"></GstExemptionStatus>
<CompanyTaxNumber xsi:nil="true"></CompanyTaxNumber>
<CancelReasonCode xsi:nil="true"></CancelReasonCode>
<DocumentFormat xsi:nil="true"></DocumentFormat>
<State xsi:nil="true"></State>
<CountyZip xsi:nil="true"></CountyZip>
<City xsi:nil="true"></City>
<InvoiceWholeOrderOnly xsi:nil="true"></InvoiceWholeOrderOnly>
<SalesOrderPromoQualifyAction xsi:nil="true"></SalesOrderPromoQualifyAction>
<SalesOrderPromoSelectAction xsi:nil="true"></SalesOrderPromoSelectAction>
<GlobalTradePromotionCodes xsi:nil="true"></GlobalTradePromotionCodes>
<eSignature xsi:nil="true"></eSignature>
<SalesForceOrderNumber>ORD-380801</SalesForceOrderNumber>
</OrderHeader>
<OrderHeader>
<CustomerPoNumber>22193037</CustomerPoNumber>
<OrderActionType>A</OrderActionType>
<NewCustomerPoNumber xsi:nil="true"></NewCustomerPoNumber>
<Supplier xsi:nil="true"></Supplier>
<Customer>027886</Customer>
<OrderDate>2016-02-11</OrderDate>
<InvoiceTerms xsi:nil="true"></InvoiceTerms>
<Currency xsi:nil="true"></Currency>
<ShippingInstrs xsi:nil="true"></ShippingInstrs>
<CustomerName>STAGE STORES DIST CTR 05099</CustomerName>
<ShipAddress1 xsi:nil="true"></ShipAddress1>
<ShipAddress2 xsi:nil="true"></ShipAddress2>
<ShipAddress3 xsi:nil="true"></ShipAddress3>
<ShipAddress4 xsi:nil="true"></ShipAddress4>
<ShipAddress5 xsi:nil="true"></ShipAddress5>
<ShipPostalCode xsi:nil="true"></ShipPostalCode>
<Email xsi:nil="true"></Email>
<OrderDiscPercent1 xsi:nil="true"></OrderDiscPercent1>
<OrderDiscPercent2 xsi:nil="true"></OrderDiscPercent2>
<OrderDiscPercent3 xsi:nil="true"></OrderDiscPercent3>
<Warehouse xsi:nil="true"></Warehouse>
<SpecialInstrs xsi:nil="true"></SpecialInstrs>
<SalesOrder xsi:nil="true"></SalesOrder>
<OrderType xsi:nil="true"></OrderType>
<MultiShipCode xsi:nil="true"></MultiShipCode>
<ShipAddressPerLine xsi:nil="true"></ShipAddressPerLine>
<AlternateReference xsi:nil="true"></AlternateReference>
<Salesperson xsi:nil="true"></Salesperson>
<Branch xsi:nil="true"></Branch>
<Area xsi:nil="true"></Area>
<RequestedShipDate xsi:nil="true"></RequestedShipDate>
<InvoiceNumberEntered xsi:nil="true"></InvoiceNumberEntered>
<InvoiceDateEntered xsi:nil="true"></InvoiceDateEntered>
<OrderComments xsi:nil="true"></OrderComments>
<Nationality xsi:nil="true"></Nationality>
<DeliveryTerms xsi:nil="true"></DeliveryTerms>
<TransactionNature xsi:nil="true"></TransactionNature>
<TransportMode xsi:nil="true"></TransportMode>
<ProcessFlag xsi:nil="true"></ProcessFlag>
<TaxExemptNumber xsi:nil="true"></TaxExemptNumber>
<TaxExemptionStatus xsi:nil="true"></TaxExemptionStatus>
<GstExemptNumber xsi:nil="true"></GstExemptNumber>
<GstExemptionStatus xsi:nil="true"></GstExemptionStatus>
<CompanyTaxNumber xsi:nil="true"></CompanyTaxNumber>
<CancelReasonCode xsi:nil="true"></CancelReasonCode>
<DocumentFormat xsi:nil="true"></DocumentFormat>
<State xsi:nil="true"></State>
<CountyZip xsi:nil="true"></CountyZip>
<City xsi:nil="true"></City>
<InvoiceWholeOrderOnly xsi:nil="true"></InvoiceWholeOrderOnly>
<SalesOrderPromoQualifyAction xsi:nil="true"></SalesOrderPromoQualifyAction>
<SalesOrderPromoSelectAction xsi:nil="true"></SalesOrderPromoSelectAction>
<GlobalTradePromotionCodes xsi:nil="true"></GlobalTradePromotionCodes>
<eSignature xsi:nil="true"></eSignature>
<SalesForceOrderNumber>ORD-380813</SalesForceOrderNumber>
</OrderHeader>
<OrderDetails>
<StockLine>
<CustomerPoLine>9999</CustomerPoLine>
<LineCancelCode xsi:nil="true"></LineCancelCode>
<StockCode>JBLC-SMH-16OZ-01</StockCode>
<StockDescription>SMH JAMAICAN LI COND. 16OZ</StockDescription>
<Warehouse xsi:nil="true"></Warehouse>
<CustomersPartNumber xsi:nil="true"></CustomersPartNumber>
<OrderQty>3.0</OrderQty>
<OrderUom>EA</OrderUom>
<Price>7.14</Price>
<PriceUom>EA</PriceUom>
<PriceCode xsi:nil="true"></PriceCode>
<AlwaysUsePriceEntered>Y</AlwaysUsePriceEntered>
<Units xsi:nil="true"></Units>
<Pieces xsi:nil="true"></Pieces>
<ProductClass xsi:nil="true"></ProductClass>
<LineDiscPercent1 xsi:nil="true"></LineDiscPercent1>
<LineDiscPercent2 xsi:nil="true"></LineDiscPercent2>
<LineDiscPercent3 xsi:nil="true"></LineDiscPercent3>
<AlwaysUseDiscountEntered xsi:nil="true"></AlwaysUseDiscountEntered>
<CustRequestDate xsi:nil="true"></CustRequestDate>
<CommissionCode xsi:nil="true"></CommissionCode>
<LineShipDate xsi:nil="true"></LineShipDate>
<LineDiscValue xsi:nil="true"></LineDiscValue>
<LineDiscValFlag xsi:nil="true"></LineDiscValFlag>
<OverrideCalculatedDiscount xsi:nil="true"></OverrideCalculatedDiscount>
<UserDefined>18</UserDefined>
<NonStockedLine xsi:nil="true"></NonStockedLine>
<NsProductClass xsi:nil="true"></NsProductClass>
<NsUnitCost xsi:nil="true"></NsUnitCost>
<UnitMass xsi:nil="true"></UnitMass>
<UnitVolume xsi:nil="true"></UnitVolume>
<StockTaxCode xsi:nil="true"></StockTaxCode>
<StockNotTaxable xsi:nil="true"></StockNotTaxable>
<StockFstCode xsi:nil="true"></StockFstCode>
<StockNotFstTaxable xsi:nil="true"></StockNotFstTaxable>
<AllocationAction xsi:nil="true"></AllocationAction>
<ConfigPrintInv xsi:nil="true"></ConfigPrintInv>
<ConfigPrintDel xsi:nil="true"></ConfigPrintDel>
<ConfigPrintAck xsi:nil="true"></ConfigPrintAck>
<TariffCode xsi:nil="true"></TariffCode>
<LineMultiShipCode xsi:nil="true"></LineMultiShipCode>
<SupplementaryUnitsFactor xsi:nil="true"></SupplementaryUnitsFactor>
<ReserveStock xsi:nil="true"></ReserveStock>
<ReserveStockRequestAllocs xsi:nil="true"></ReserveStockRequestAllocs>
<TradePromotionCodes xsi:nil="true"></TradePromotionCodes>
</StockLine>
</OrderDetails>
</Orders>
</SalesOrders>
We tried following xslt stylesheet on it : **
It tells about two template at at time. But when i am applying both at same time it is not working fo us. it only split the XML but did not remove xsi:nil ="true" element from Original XML. but when i am applying on seperate basis it removes the tag xsi:nil ="true" from documents.
Here is description of XSL file
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes"/>
<xsl:output encoding="Windows-1252"/>
<xsl:template match="*/@*"/>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="/">
<xsl:for-each-group select="SalesOrders/Orders" group-by="OrderHeader">
<xsl:result-document href="SORTOIDOC{position()}.xml">
<SalesOrders>
<xsl:copy-of select="current-group()"/>
</SalesOrders>
</xsl:result-document>
</xsl:for-each-group>
</xsl:template>
</xsl:stylesheet>
**
OutPut of each splitted XML should look like after split and removal of xsi:nil
**<?xml version="1.0" encoding="Windows-1252"?>
<SalesOrders xmlns:xsd="http://www.w3.org/2001/XMLSchema-instance" xsd:noNamespaceSchemaLocation="xmlfilename.XSD">
<Orders>
<OrderHeader>
<CustomerPoNumber>C1000</CustomerPoNumber>
<OrderActionType>A</OrderActionType>
<NewCustomerPoNumber/>
<Supplier/>
<Customer>000010</Customer>
<OrderDate>2006-11-04</OrderDate>
<InvoiceTerms>0</InvoiceTerms>
<Currency>$</Currency>
<ShippingInstrs>Ship via Hong Kong</ShippingInstrs>
<CustomerName>The SYSPRO Outdoors Company</CustomerName>
<ShipAddress1>This is the alternate delivery address 1</ShipAddress1>
<ShipAddress2>This is the alternate delivery address 2</ShipAddress2>
<ShipAddress3>This is the alternate delivery address 3</ShipAddress3>
<ShipAddress4>This is the alternate delivery address 4</ShipAddress4>
<ShipAddress5>This is the alternate delivery address 5</ShipAddress5>
<ShipPostalCode>90210</ShipPostalCode>
<Email>Sender001@Sender001.com</Email>
<OrderDiscPercent1>2.50</OrderDiscPercent1>
<OrderDiscPercent2>1.50</OrderDiscPercent2>
<OrderDiscPercent3>1.00</OrderDiscPercent3>
<Warehouse>E</Warehouse>
<SpecialInstrs>Handle with care</SpecialInstrs>
<SalesOrder>221124</SalesOrder>
<OrderType>1</OrderType>
<MultiShipCode/>
<ShipAddressPerLine/>
<AlternateReference/>
<Salesperson>100</Salesperson>
<Branch/>
<Area/>
<RequestedShipDate>2006-12-20</RequestedShipDate>
<InvoiceNumberEntered/>
<InvoiceDateEntered/>
<OrderComments/>
<Nationality/>
<DeliveryTerms/>
<TransactionNature/>
<TransportMode/>
<ProcessFlag/>
<TaxExemptNumber/>
<TaxExemptionStatus/>
<GstExemptNumber/>
<GstExemptionStatus/>
<CompanyTaxNumber/>
<CancelReasonCode/>
<DocumentFormat/>
<State/>
<CountyZip/>
<City/>
<InvoiceWholeOrderOnly/>
<SalesOrderPromoQualifyAction>W</SalesOrderPromoQualifyAction>
<SalesOrderPromoSelectAction>A</SalesOrderPromoSelectAction>
<GlobalTradePromotionCodes>GLACC,GLFREE</GlobalTradePromotionCodes>
<eSignature/>
</OrderHeader>
<OrderDetails>
<StockLine>
<CustomerPoLine>1</CustomerPoLine>
<LineActionType>A</LineActionType>
<LineCancelCode/>
<StockCode>B100</StockCode>
<StockDescription>Bicycle</StockDescription>
<Warehouse>FG</Warehouse>
<CustomersPartNumber>FF334221</CustomersPartNumber>
<OrderQty>5</OrderQty>
<OrderUom>EA</OrderUom>
<Price>400</Price>
<PriceUom>EA</PriceUom>
<PriceCode/>
<AlwaysUsePriceEntered/>
<Units/>
<Pieces/>
<ProductClass/>
<LineDiscPercent1>0.5</LineDiscPercent1>
<LineDiscPercent2>0</LineDiscPercent2>
<LineDiscPercent3>0</LineDiscPercent3>
<AlwaysUseDiscountEntered>N</AlwaysUseDiscountEntered>
<CustRequestDate>2006-12-20</CustRequestDate>
<CommissionCode/>
<LineShipDate/>
<LineDiscValue>0</LineDiscValue>
<LineDiscValFlag/>
<OverrideCalculatedDiscount/>
<UserDefined>USER</UserDefined>
<NonStockedLine/>
<NsProductClass>NSPR</NsProductClass>
<NsUnitCost/>
<UnitMass/>
<UnitVolume/>
<StockTaxCode/>
<StockNotTaxable/>
<StockFstCode/>
<StockNotFstTaxable/>
<AllocationAction/>
<ConfigPrintInv/>
<ConfigPrintDel/>
<ConfigPrintAck/>
<TariffCode/>
<LineMultiShipCode/>
<SupplementaryUnitsFactor/>
<ReserveStock/>
<ReserveStockRequestAllocs/>
<TradePromotionCodes>BIKEACCR,FREE1</TradePromotionCodes>
</StockLine>
</OrderDetails>
</Orders>
</SalesOrders>**
Any help on it would be much appreciated.
Thanks in advance.
Here is my try:
phase1
, transform the document into it by removing the attributes(check themode
attribute on templates and apply-templates to apply the desired templates).That's because your first two templates are never applied. Your last template, the one matching the root
/
node, is the first one to be executed - and this template does not contain anyxsl:apply-templates
instructions.If you change:
to:
you will get the expected result.
P.S. Note that your first template:
will remove all attributes, not only the
xsi:nil ="true"
ones as stated in your question. To make it work exactly as stated, it needs to be changed to:Added:
To avoid this, change:
to:
To summarize, your stylesheet should look like this:
XSLT 2.0
Added 2:
IMHO, the splitting you show us does not work correctly as you claim. But that should be subject for another question.