473,408 Members | 2,832 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,408 software developers and data experts.

XmlDocument.LoadXml and namespaces

Hi;

Once I have loaded an xml file into a DOM, is there any way to then get any
namespace declarations that were in the xml file? Or are those just discarded
as the DOM is populated?

And if you can't get it from the DOM, any other way to get the namespace(s)?
I'm assuming doing a SAX read which returns each element including NameSpaces
and pull it form that (and build up the DOM at the same time)?

In my case I get a Stream so I can't read it twice as the Stream may not
support reset. And it may have NS elements - but I don't know if there are
any or what they are except by reading the Stream.

--
thanks - dave
Nov 12 '05 #1
11 4298
David Thielen wrote:
Once I have loaded an xml file into a DOM, is there any way to then get any
namespace declarations that were in the xml file? Or are those just discarded
as the DOM is populated?


Of course not. You can select namespace declarations using
doc.SelectNodes("//namespace::*").

--
Oleg Tkachenko [XML MVP, MCAD]
http://www.xmllab.net
http://blog.tkachenko.com
Nov 12 '05 #2
Hi;

This sort-of worked. I have 3 namespaces declared in the header of the file.
The SelectNodes("//namespace::*") gave me 36 nodes. I did not check each one
but it appeared to be the 3 namespaces repeated over and over.

Any idea why I didn't get just 3?

--
thanks - dave
"Oleg Tkachenko [MVP]" wrote:
David Thielen wrote:
Once I have loaded an xml file into a DOM, is there any way to then get any
namespace declarations that were in the xml file? Or are those just discarded
as the DOM is populated?


Of course not. You can select namespace declarations using
doc.SelectNodes("//namespace::*").

--
Oleg Tkachenko [XML MVP, MCAD]
http://www.xmllab.net
http://blog.tkachenko.com

Nov 12 '05 #3
For the xml:
<root xmlns="http://www.test.org" xmlns:sns="http://www.test.org/sub"
xmlns:mns="http://www.test.org/mini">
<data>
<items>
<item id="1">
<sns:subItem sid="11">dave</sns:subItem>
<sns:subItem sid="12">thielen</sns:subItem>
</item>
<item id="2">
<sns:subItem sid="21">shirley</sns:subItem>
</item>
</items>
<mns:more>dave thielen</mns:more>
</data>
</root>

The nodes returned are:
mns=http://www.test.org/mini
sns=http://www.test.org/sub
{default}=http://www.test.org
xml=http://www.w3.org/XML/1998/namespace
mns=http://www.test.org/mini
sns=http://www.test.org/sub
{default}=http://www.test.org
xml=http://www.w3.org/XML/1998/namespace
mns=http://www.test.org/mini
sns=http://www.test.org/sub
{default}=http://www.test.org
xml=http://www.w3.org/XML/1998/namespace
mns=http://www.test.org/mini
sns=http://www.test.org/sub
{default}=http://www.test.org
xml=http://www.w3.org/XML/1998/namespace
mns=http://www.test.org/mini
sns=http://www.test.org/sub
{default}=http://www.test.org
xml=http://www.w3.org/XML/1998/namespace
mns=http://www.test.org/mini
sns=http://www.test.org/sub
{default}=http://www.test.org
xml=http://www.w3.org/XML/1998/namespace
mns=http://www.test.org/mini
sns=http://www.test.org/sub
{default}=http://www.test.org
xml=http://www.w3.org/XML/1998/namespace
mns=http://www.test.org/mini
sns=http://www.test.org/sub
{default}=http://www.test.org
xml=http://www.w3.org/XML/1998/namespace
mns=http://www.test.org/mini
sns=http://www.test.org/sub
{default}=http://www.test.org
xml=http://www.w3.org/XML/1998/namespace

??? - thanks - dave
Nov 12 '05 #4


David Thielen wrote:
This sort-of worked. I have 3 namespaces declared in the header of the file.
The SelectNodes("//namespace::*") gave me 36 nodes. I did not check each one
but it appeared to be the 3 namespaces repeated over and over.

Any idea why I didn't get just 3?


Because in the XPath data model any element has in scope namespace nodes
and that way if you for instance declare namespaces on the root element
and do not declare/redeclare namespaces on any child elements then
besides the root element all child elements also have those namespaces
in scope as nodes of their own.

--

Martin Honnen --- MVP XML
http://JavaScript.FAQTs.com/
Nov 12 '05 #5
David Thielen wrote:
This sort-of worked. I have 3 namespaces declared in the header of the file.
The SelectNodes("//namespace::*") gave me 36 nodes. I did not check each one
but it appeared to be the 3 namespaces repeated over and over.

Any idea why I didn't get just 3?


Select unique ones (and omit default "xml" namespace):
//namespace::*[name() != 'xml'][not(../../namespace::*=.)]

--
Oleg Tkachenko [XML MVP, MCAD]
http://www.xmllab.net
http://blog.tkachenko.com
Nov 12 '05 #6
Oh right, that makes a lot of sense -- thanks - dave
"Martin Honnen" wrote:


David Thielen wrote:
This sort-of worked. I have 3 namespaces declared in the header of the file.
The SelectNodes("//namespace::*") gave me 36 nodes. I did not check each one
but it appeared to be the 3 namespaces repeated over and over.

Any idea why I didn't get just 3?


Because in the XPath data model any element has in scope namespace nodes
and that way if you for instance declare namespaces on the root element
and do not declare/redeclare namespaces on any child elements then
besides the root element all child elements also have those namespaces
in scope as nodes of their own.

--

Martin Honnen --- MVP XML
http://JavaScript.FAQTs.com/

Nov 12 '05 #7
Hi;

This worked great but I don't understand it totally. I get the [name() !=
'xml']

But what does [not(../../namespace::*=.)] mean? I'm totally lost on how that
works.

Also, when you do xpath[a][b] is that saying both a and b must be true? Can
you also do //namespace::*[name() != 'xml'] and [not(../../namespace::*=.)]
as the same thing? Or am I not understanding this?

I'm asking the above questions because I just want to understand xpath better.

--
thanks - dave
"Oleg Tkachenko [MVP]" wrote:
David Thielen wrote:
This sort-of worked. I have 3 namespaces declared in the header of the file.
The SelectNodes("//namespace::*") gave me 36 nodes. I did not check each one
but it appeared to be the 3 namespaces repeated over and over.

Any idea why I didn't get just 3?


Select unique ones (and omit default "xml" namespace):
//namespace::*[name() != 'xml'][not(../../namespace::*=.)]

--
Oleg Tkachenko [XML MVP, MCAD]
http://www.xmllab.net
http://blog.tkachenko.com

Nov 12 '05 #8
David Thielen wrote:

But what does [not(../../namespace::*=.)] mean? I'm totally lost on how that
works.
In XPath data model namespace nodes are propagated/copied down the tree
- each node in a subtree has namespace node for each namespace in context.
This predicate checks that parent of the element bearing the namespace
node doesn't have such namespace node. Effectively that allows to select
only namespace nodes on elements where namespace is declared.

Also, when you do xpath[a][b] is that saying both a and b must be true?
Yes.
Can
you also do //namespace::*[name() != 'xml'] and [not(../../namespace::*=.)]
as the same thing? Or am I not understanding this?


Yes, that's the same.

--
Oleg Tkachenko [XML MVP, MCAD]
http://www.xmllab.net
http://blog.tkachenko.com
Nov 12 '05 #9
Hi;

Ok, that makes sense. To make sure I understand this:
.../../namespace::* is getting the grandparent of the node on (../../) and
then getting any nodes in that element that start with namespace:: - why not
.../namespace::* - isn't that the parent?

And then the =. is saying equal to the node presently on . being the node on.

Is that correct?

--
thanks - dave
"Oleg Tkachenko [MVP]" wrote:
David Thielen wrote:

But what does [not(../../namespace::*=.)] mean? I'm totally lost on how that
works.


In XPath data model namespace nodes are propagated/copied down the tree
- each node in a subtree has namespace node for each namespace in context.
This predicate checks that parent of the element bearing the namespace
node doesn't have such namespace node. Effectively that allows to select
only namespace nodes on elements where namespace is declared.

Also, when you do xpath[a][b] is that saying both a and b must be true?


Yes.
Can
you also do //namespace::*[name() != 'xml'] and [not(../../namespace::*=.)]
as the same thing? Or am I not understanding this?


Yes, that's the same.

--
Oleg Tkachenko [XML MVP, MCAD]
http://www.xmllab.net
http://blog.tkachenko.com

Nov 12 '05 #10


David Thielen wrote:

Ok, that makes sense. To make sure I understand this:
../../namespace::* is getting the grandparent of the node on (../../) and
then getting any nodes in that element that start with namespace:: - why not
../namespace::* - isn't that the parent?


It helps looking into the XPath spec which here
<http://www.w3.org/TR/xpath#namespace-nodes>
says about the namespace nodes:
"Each element has an associated set of namespace nodes, one for each
distinct namespace prefix that is in scope for the element (including
the xml prefix, which is implicitly declared by the XML Namespaces
Recommendation [XML Names]) and one for the default namespace if one is
in scope for the element. The element is the parent of each of these
namespace nodes"
thus if you have a predicate on
//namespace::*
then
..
gives you the element the namespace node belongs to and
../..
gives the parent node of that element so that the predicate
not(../../namespace::*=.)
compares the namespace node on one element with the namespace nodes
attached to the parent element.


--

Martin Honnen --- MVP XML
http://JavaScript.FAQTs.com/
Nov 12 '05 #11
Hi;

I think I've read the spec at least 5 times. And I have 4 books on XML/XPath
that I have gone through. But I still trip on stuff - and figure it's best to
ask and ask until I know I understand a point well. I appreciate everyone
explaining the why behind this.

As soon as you said the .. is the node containing the namespace I realized
why it's ../.. instead of .. - should have figured that out.

One thing that hit me while going through this, it seems that xpath
basically walks the tree node by node to determine if that node matches the
xpath. If it does, it adds that node to the node(s) to be returned and walks
on to the next one. (Obviously in implementation it does not walk nodes it
knows can't match.)

So it makes sense that you can use . in the xpath to represent the node you
are presently evaluating. But I hadn't really comprehended that before as a
SQL select has no similiar concept.

Anyways, thanks for the lesson - I think I understand this now and this is
definitely useful info.

--
thanks - dave
"Martin Honnen" wrote:


David Thielen wrote:

Ok, that makes sense. To make sure I understand this:
../../namespace::* is getting the grandparent of the node on (../../) and
then getting any nodes in that element that start with namespace:: - why not
../namespace::* - isn't that the parent?


It helps looking into the XPath spec which here
<http://www.w3.org/TR/xpath#namespace-nodes>
says about the namespace nodes:
"Each element has an associated set of namespace nodes, one for each
distinct namespace prefix that is in scope for the element (including
the xml prefix, which is implicitly declared by the XML Namespaces
Recommendation [XML Names]) and one for the default namespace if one is
in scope for the element. The element is the parent of each of these
namespace nodes"
thus if you have a predicate on
//namespace::*
then
..
gives you the element the namespace node belongs to and
../..
gives the parent node of that element so that the predicate
not(../../namespace::*=.)
compares the namespace node on one element with the namespace nodes
attached to the parent element.


--

Martin Honnen --- MVP XML
http://JavaScript.FAQTs.com/

Nov 12 '05 #12

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

6
by: Yechezkal Gutfreund | last post by:
I have been using the following code (successfully) to read Xml formated text packets from a TCP stream. The output from the server stream consists of a sequence of well formed Xml documents...
1
by: Martin Honnen | last post by:
With both .NET 1.0 and 1.1 I have found the following strange behaviour where System.Xml.XmlDocument.LoadXml doesn't throw an error when parsing a text node with a character reference to an invalid...
4
by: Robert Rossney | last post by:
I'm trying to send and receive XmlDocument objects using the System.Messaging.dll functions. The code I've written follows, as best I can tell, the methodology used in the sample code for the...
2
by: Eric Zechman via .NET 247 | last post by:
I have a project in which I get xml posted via a hidden form field (data=<xml></xml>). People are entering names like Bill & Sandy Smith. this is coming over as:...
1
by: AJ Brown | last post by:
I'm loading an XmlDocument object from a string using LoadXml. The string is a well-formed XML fragment (see example) and loads fine, however there are entities (&amp;) within attribute values. The...
2
by: Dave | last post by:
Hi, Is there an easier way to pull a subset of nodes from one XmlDocument to another? I have the code below but would like to know if there is a more streamlined method. Thanks, Dave ...
19
by: David Thielen | last post by:
Hi; If there are no namespaces this works fine for me. But if the xml has namespaces, then I get either no node back or an exception. Here is the sample xml: <root xmlns="http://www.test.org"...
2
by: Lupina | last post by:
Hi I want load whole xml file, I try do it in the same way as I did it in windows application. try { XmlDocument myDoc = new XmlDocument();
4
by: Carlos Albert | last post by:
Hello, Would you tell me if there is a way to extract a single node as a new xmldocument? Thanks.
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...
0
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome a new...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.