XML Editor
Sign up for a WebBoard account Sign Up Keyword Search Search More Options... Options
Chat Rooms Chat Help Help News News Log in to WebBoard Log in Not Logged in
Show tree view Topic
Topic Page 1 2 3 4 5 6 7 8 9 Go to previous topicPrev TopicGo to next topicNext Topic
Postnext
Justin KohlheppSubject: XSLT namespace output
Author: Justin Kohlhepp
Date: 17 Apr 2007 10:47 AM
I have an XSLT which copies an Excel SpreadsheetML doc and modifies it. Instead of the namespace declarations rolling up to the outermost node that it can, I am getting them on every node. I reduced the XSLT to find the problem. I have this:
<xsl:stylesheet
version="1.0"
xmlns="urn:schemas-microsoft-com:office:spreadsheet"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet"
xmlns:o="urn:schemas-microsoft-com:office:office"
xmlns:x="urn:schemas-microsoft-com:office:excel"
xmlns:html="http://www.w3.org/TR/REC-html40">
<xsl:output method="xml" omit-xml-declaration="no" indent="no"/>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>

With that, I get output that looks like this:
<Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet" ...>
<!-- Snip -->
<ExcelWorkbook xmlns="urn:schemas-microsoft-com:office:excel">
<WindowHeight xmlns="urn:schemas-microsoft-com:office:spreadsheet">11640</WindowHeight>
<WindowWidth xmlns="urn:schemas-microsoft-com:office:spreadsheet">15195</WindowWidth>
<WindowTopX xmlns="urn:schemas-microsoft-com:office:spreadsheet">360</WindowTopX>
<WindowTopY xmlns="urn:schemas-microsoft-com:office:spreadsheet">120</WindowTopY>
<ProtectStructure xmlns="urn:schemas-microsoft-com:office:spreadsheet">False</ProtectStructure>
<ProtectWindows xmlns="urn:schemas-microsoft-com:office:spreadsheet">False</ProtectWindows>
</ExcelWorkbook>
<!-- Snip -->
</Workbook>

If I remove the xmlns="urn:schemas-microsoft-com:office:spreadsheet" from the XSLT then my output looks correct, like this:
<Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet" ...>
<!-- Snip -->
<ExcelWorkbook xmlns="urn:schemas-microsoft-com:office:excel">
<WindowHeight>11640</WindowHeight>
<WindowWidth>15195</WindowWidth>
<WindowTopX>360</WindowTopX>
<WindowTopY>120</WindowTopY>
<ProtectStructure>False</ProtectStructure>
<ProtectWindows>False</ProtectWindows>
</ExcelWorkbook>
<!-- Snip -->
</Workbook>

Why does having that default NS declaration in the XSLT cause the output to not roll up the NS? In general, how does the XSLT processor decide where to put NS declarations? Is there any documentation on this?

Thanks in advance,

~ Justin

Postnext
(Deleted User) Subject: XSLT namespace output
Author: (Deleted User)
Date: 18 Apr 2007 05:28 AM
Hi Justin,
which XSLT processor are you using?

Alberto

Posttop
Justin KohlheppSubject: XSLT namespace output
Author: Justin Kohlhepp
Date: 18 Apr 2007 08:43 AM
.NET Framework 1.1

~ Justin

 
Topic Page 1 2 3 4 5 6 7 8 9 Go to previous topicPrev TopicGo to next topicNext Topic
Download A Free Trial of Stylus Studio 6 XML Professional Edition Today! Powered by Stylus Studio, the world's leading XML IDE for XML, XSLT, XQuery, XML Schema, DTD, XPath, WSDL, XHTML, SQL/XML, and XML Mapping!  
go

Log In Options

Site Map | Privacy Policy | Terms of Use | Trademarks
Stylus Scoop XML Newsletter:
W3C Member
Stylus Studio® and DataDirect XQuery ™are from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2016 All Rights Reserved.