public static XmlDocument getDoc(String path)//加載xml文檔 { XmlDocument doc = new XmlDocument(); doc.Load(path); return doc; } /// <summary> /// 返回找到的節點下標 /// </summary> /// <param name="path">xml文件路徑</param> /// <param name="bname">書名</param> /// <returns></returns> public static int getPosition(String path,string node, String bname) { int i; XmlDocument doc = new XmlDocument(); doc.Load(path); XmlNodeList nodeList = doc.SelectSingleNode(node).ChildNodes; for (i = 0; i < nodeList.Count; i++) { if (nodeList[i].ChildNodes[0].InnerText == bname) { return i; } } return -1; }
1.遍歷
/// <summary> /// 遍歷數據 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void btnRead_Click(object sender, EventArgs e) { XmlDocument doc = getDoc("books.xml");//加載xml文檔,books文件存放於 foreach (XmlElement root in doc.DocumentElement.ChildNodes)//遍歷根的子節點 { Response.Write("<script>document.write('<br/>');</script>"); Response.Write("<script>document.write('" + root.Name + "');</script>");//節點名root.Name book foreach (XmlElement item in root.ChildNodes) { Response.Write("<script>document.write('" + item.Name + "'+':'+'" + item.InnerText + "');</script>");//輸出節點名和文本節點的值 Response.Write("<script>document.write('<br/>');</script>"); } } }
2.查找
/// <summary> /// 查找 /// </summary> /// <param name="path">文件路徑</param> /// <param name="node">節點</param> /// <param name="bname">查找關鍵字</param> /// <returns>XmlNode</returns> public static XmlNode Find(string path,string node,string bname) { XmlDocument doc = new XmlDocument(); doc.Load(path);//加載xml文檔 XmlNodeList nodeList = doc.SelectSingleNode(node).ChildNodes; int i = getPosition(path, node, bname);// if (i >= 0) return nodeList[i]; else return null; }
3.刪除節點
/// <summary> /// 刪除元素、屬性 /// </summary> /// <param name="path">文件</param> /// <param name="node">指定節點的父節點</param> /// <param name="attribute">為空時刪除節點,否則刪除屬性</param> /// <param name="bname"></param> public static void Delete(string path,string node,string attribute,string bname) { XmlDocument doc = new XmlDocument(); doc.Load(path); XmlNode root = doc.SelectSingleNode(node); XmlNodeList nodeList = doc.SelectSingleNode(node).ChildNodes; int i = getPosition(path, node, bname);//返回指定的節點下標 if (i >= 0) { if (attribute.Equals("")) { root.RemoveChild(nodeList[i]); } else { XmlElement xn = (XmlElement)nodeList[i]; xn.RemoveAttribute(attribute); } } doc.Save(path); }
4.添加
/// <summary> /// 添加元素值 /// </summary> /// <param name="path"></param> /// <param name="node"></param> /// <param name="element"></param> /// <param name="value"></param> /// <param name="i">插入的下標,如果為負,默認從最後一個節點插入</param> /// <returns></returns> public static bool Add(string path,string node,string element,string value,int i) { XmlDocument doc = new XmlDocument(); doc.Load(path); XmlNodeList nodeList = doc.SelectNodes(node); XmlNode newNode = doc.SelectSingleNode(node).LastChild; if (i < 0 || i > nodeList.Count-1)//如果小於0或者大於節點長度,默認從最後一個節點添加 { XmlElement newElement = doc.CreateElement(element);//創建元素 newElement.InnerText = value;//賦值 newNode.AppendChild(newElement); } else { XmlElement newElement = doc.CreateElement(element); newElement.InnerText = value; nodeList[i - 1].AppendChild(newElement); } doc.Save(path); return true; }
文件路徑:... bin\Debug\School.xml
<?xml version="1.0" encoding="utf-8"?>
<Class>
<Student Id="1">
<Age>20</Age>
<Name>AAA</Name>
</Student>
<Student Id="2">
<Age>22</Age>
<Name>BBB</Name>
</Student>
</Class>
---------------------------------------------------
XmlDocument doc = new XmlDocument();
doc.Load("School.xml");
XmlElement root= doc.DocumentElement;
foreach (XmlNode item in root.ChildNodes)
{
if (item.Attributes["Id"].Value == "1")
{
item["Age"].InnerText = "19";
item["Name"].InnerText = "CCC";
}
if (item.Attributes["Id"].Value == "2")
{
item["Age"].InnerText = "23";
item["Name"].InnerText = "18";
}
}
doc.Save("School.xml");
SAX處理的優點非常類似於流媒體的優點。分析能夠立即開始,而不是等待所有的數據被處理。而且,由於應用程序只是在讀取數據時檢查數據,因此不需要將數據存儲在內存中。這對於大型文檔來說是個巨大的優點。事實上,應用程序甚至不必解析整個文檔;它可以在某個條件得到滿足時停止解析。一般來說,SAX還比它的替代者DOM快許多。
選擇DOM還是選擇SAX? 對於需要自己編寫代碼來處理XML文檔的開發人員來說, 選擇DOM還是SAX解析模型是一個非常重要的設計決策。 DOM采用建立樹形結構的方式訪問XML文檔,而SAX采用的事件模型。
DOM解析器把XML文檔轉化為一個包含其內容的樹,並可以對樹進行遍歷。用DOM解析模型的優點是編程容易,開發人員只需要調用建樹的指令,然後利用navigation APIs訪問所需的樹節點來完成任務。可以很容易的添加和修改樹中的元素。然而由於使用DOM解析器的時候需要處理整個XML文檔,所以對性能和內存的要求比較高,尤其是遇到很大的XML文件的時候。由於它的遍歷能力,DOM解析器常用於XML文檔需要頻繁的改變的服務中。
SAX解析器采用了基於事件的模型,它在解析XML文檔的時候可以觸發一系列的事件,當發現給定的tag的時候,它可以激活一個回調方法,告訴該方法制定的標簽已經找到。SAX對內存的要求通常會比較低,因為它讓開發人員自己來決定所要處理的tag.特別是當開發人員只需要處理文檔中所包含的部分數據時,SAX這種擴展能力得到了更好的體現。但用SAX解析器的時候編碼工作會比較困難,而且很難同時訪問同一個文檔中的多處不同數據。