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解析器的時候編碼工作會比較困難,而且很難同時訪問同一個文檔中的多處不同數據。