I'm parsing Xml data which has entries like this:
<item name="UserText" type_name="gh_string" type_code="10"> </item>
I'm supposed to read the 6 spaces as a String, but both the InnerText and InnerXml values of the System.Xml.XmlNode are zero length Strings.
Is there any way I can get at this whitespace data in existing files and what do I need to do in the future to prevent this sort of screw up?
XML is ignoring that whitespace. If you need to preserve it, you should insert an xml:space="preserve"
attribute into your elements. Something like this, which I think is going to preserve your whitespace wherever the XML is consumed.
<item xml:space="preserve" name="UserText" type_name="gh_string" type_code="10"> </item>
Another option that will work with LINQ-to-XML is to use the PreserveWhitespace load option. Example:
XElement element = XElement.Parse(xml, LoadOptions.PreserveWhitespace);
You should also be able wrap the whitespace in a CData tag, haven't tested.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With