大家在.NET中處理XML文檔的時候,經常會需要找到文檔中的某個節點的數據。要找到某個節點,有許多種方法,在這里我就把幾種常用的方法給大家總結一下。
首先,我們要做的是要把一個XML文檔裝入到一個XmlDocument對象中去。
先引用幾個名字空間:
using System.Xml;
using System.Xml.Xsl;
using System.Xml.XPath;
這幾個名字空間大家根據名字就知道它的意思了,我就不在這兒多說了。然后就是裝入XML文件的代碼,方法如下:
String xmlfile="c:/member.xml"; //其中的xmlfile是你要載入的XML文件的路徑。
XmlDocument myDoc = new XmlDocument(); //定義一個XmlDocument對象。
myDoc.Load(xmlfile);
這樣,我們就有一個叫myDoc的XML文檔。我們現在就來找這個文檔中的一些節點。我們先來看這個XML文件的內容。
< ?xml version="1.0" encoding="UTF-8"?>
< members>
< member>
< name>Tim
< hobby>reading
< homepage>www.aspcool.com
< /member>
< member>
< name>Sandy
< hobby>learning
< /member>
< member>
< name>Shally
< hobby>tranlating
< /member>
< member>
< name>Christine
< hobby>working
< /member>
< /members>
我們現在可以用下面的方法找到name為tim的節點:
myDoc.ChildNodes.Item(1).ChildNodes.Item(0).FirstChild.InnerText
這個方法要求我們一層層向內找我們需要的數據,如果層次很多的話,做起來就會很費勁,也容易出錯。幸好.NET給我們提供了另外一個方法SelectSingleNode和SelectNodes方法可以讓我們直接找到所要的數據。比如,我們要找姓名為“Tim”的用戶的hobby,我們可以用下面的方法:
myDoc.SelectSingleNode ("//member[name='Tim']").ChildNodes.Item(1).InnerText
其中//代表里面任意層的子節點。這樣我們就可以很快的找到所要的東西。SelectSingleNode是找到一個單一的節點,SelectNodes可以找到許多節點。
新聞熱點
疑難解答