Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to include space in XML tag/element which gets transformed by XSLT into Excel sheet [duplicate]

I have an XML which gets transformed with an XSLT into an Excel sheet on a webpage. The element tags in XML becomes column headers in Excel. There are columns which would like to have spaces. We don't like underscores or hyphens coming in Excel sheet headers. How can I incorporate space in an XML tag/element? I tried putting   or %20 or #&20; etc. (all kinds of syntax) but all of them shows error on XML editor itself saying this hexadecimal character is not allowed.

My XML is

<ClientArray>
  <Client>
    <LastName>Aanonsen</LastName>
    <FirstName>Fred</FirstName>
    <Additional Remarks><Additional Remarks>
  </Client>

I want a space between Additional and Remarks in the tag. Please help. Thanks in advance.

like image 903
Enggr Avatar asked Aug 13 '10 21:08

Enggr


1 Answers

How to I incorporate space in an XML tag/element? I tried putting or %20 or &#20; etc etc . (all kinds of syntax) but all of them shows error on xml editor itself saying this hexadecimal character is not allowed

You can't. The W3C XML specification strictly defines the syntax of names. A name can only start with a letter character (this includes underscore), then the next characters can be letter characters or numbers or the hyphen, but the space is a delimiter and is not allowed as part of any name.

More precisely, here are the exact rules from the spec:

[4a]    NameChar    ::=    NameStartChar | "-" | "." | [0-9] | #xB7 | [#x0300-#x036F] | [#x203F-#x2040] 
[5]    Name    ::=    NameStartChar (NameChar)* 

To overcome this restriction you have to modify your XSLT transformation so that it outputs as Excel column names more convenient to read strings than XML names.

like image 196
Dimitre Novatchev Avatar answered Sep 23 '22 15:09

Dimitre Novatchev