tags:

views:

69

answers:

6

Hey,

I'm trying to find a way to get the total number of child nodes from an XmlNode recursively.

That it is to say I want to count all the children, grand children etc.

I think its something like

node.SelectNodes(<fill in here>).Count

but I don't know what the XPath is.

Thanks

A: 

I think this will do it for you though not through xPath:

void CountNode(XmlNode node, ref int count)
{
    count += node.ChildNodes.Count;

    foreach (XmlNode child in node.ChildNodes)
    {
        CountNode(child, ref count);
    }
}

For reference here is a link to the count function in xpath.

http://msdn.microsoft.com/en-us/library/ms256103.aspx

so if you were looking for all the same type of nodes you could do

//Your_node

to select all the nodes

//*
Kevin
`descendant::Your_Node` selects all nodes *called* `Your_Node` below the current node
svick
A: 

If you're doing an unfiltered count, which your question implies, you could just traverse the them using the ChildNodes property:

private int CountChildren(XmlNode node)
{
   int total = 0;

   foreach (XmlNode child in node.ChildNodes)
   {
      total++;
      total += CountChildren(child);
   }
   return total;
}
Steve Danner
@Steve Danner, @Kevin yes I know I can do it recursively, just presumed there would be an xpath way
mjmcloug
A: 

You could use somthing like this:

private static int CountNodes(XmlNode node)
{
    int count = 0;

    foreach (XmlNode childNode in node.ChildNodes)
    {
        count += CountNodes(childNode);
    }

    return count + node.ChildNodes.Count;
}
Andrew Bezzub
+3  A: 
using System.Xml.Linq;

node.DescendantNodes().Count();
Mel Gerats
+2  A: 

The XPath you are after is:

descendant::node() (1)

or

descendant::* (2)

The first XPath expresion (1) above selects any node (text-node, processing-instruction, comment, element) in the subtree rooted by the current node.

(2) selects any element node in the subtree rooted by the current node.

Dimitre Novatchev
(2) is equivalent to `descendant-or-self::*`, but the question was only for the child nodes, not including the current node (of course, it's just a matter of subtracting 1)
svick
@svick: Thanks, corrected.
Dimitre Novatchev
This is also correct! but he needs the points more than you :S
mjmcloug
+2  A: 

XPath supports something called Axis specifier, so the code you're looking for is

node.SelectNodes("descendant::*").Count
svick