tags:

views:

41

answers:

1

I have an XML document as follows:

<directory>
<file><monitored>0</monitored>
<xferStatus>1</xferStatus>
<name>test1.txt</name>
<size>7</size>
<created>03/31/10 11:30:02 AM</created>
<modified>03/31/10 11:30:00 AM</modified>
<tPathList><tPath>http://hwcdn.net/p2f4h2b5/cds/testing/test1.txt&lt;/tPath&gt;
</tPathList>
<tPath>http://hwcdn.net/p2f4h2b5/cds/testing/test1.txt&lt;/tPath&gt;
<oPathList><oPath>http://hwcdn.net/p2f4h2b5/w9m3i4q9/test1.txt&lt;/oPath&gt;
</oPathList>
<oPath>http://hwcdn.net/p2f4h2b5/w9m3i4q9/test1.txt&lt;/oPath&gt;
<aPath></aPath>
</file>

<file><monitored>0</monitored>
<xferStatus>1</xferStatus>
<name>GenericDAO.cs</name>
<size>1843</size>
<created>03/31/10 11:41:10 AM</created>
<modified>03/31/10 11:41:10 AM</modified>
<tPathList><tPath>http://hwcdn.net/p2f4h2b5/cds/testing/GenericDAO.cs&lt;/tPath&gt;
</tPathList>
<tPath>http://hwcdn.net/p2f4h2b5/cds/testing/GenericDAO.cs&lt;/tPath&gt;
<oPathList><oPath>http://hwcdn.net/p2f4h2b5/w9m3i4q9/GenericDAO.cs&lt;/oPath&gt;
</oPathList>
<oPath>http://hwcdn.net/p2f4h2b5/w9m3i4q9/GenericDAO.cs&lt;/oPath&gt;
<aPath></aPath>
</file>
<nEntries>2</nEntries>
</directory>

Well there are two files in the document, how can i recursively or iteratively get the files, sizes, etc.. ?

The response was in string format, and converted to XML as follows :

XmlTextReader textReader = new XmlTextReader(hwresponse);
+4  A: 

Try Linq to XML (System.Xml.Linq namespace.) Example:

XDocument document = XDocument.Parse(xml); // xml string
var query = from file in document.Descendants("file")
            select new
                {
                    Monitored = (int)file.Element("monitored"),
                    Name = (string)file.Element("name"),
                    Size = (int)file.Element("size")
                };

foreach (var file in query)
{
    Console.WriteLine("{0}\t{1}", file.Name, file.Size);
}
Anthony Pegram