XML 增、刪、改
樣本XML文件(bookstore.xml)
<?xml version="1.0" encoding="gb2312"?> <bookstore> <book genre="fantasy" ISBN="2-3631-4"> <title>Oberon's Legacy</title> <author>Corets, Eva</author> <price>5.95</price> </book> </bookstore>
1、往<bookstore>節點中插入一個<book>節點:
XmlDocument xmlDoc = new XmlDocument(); xmlDoc.Load("E:\\bookstore.xml"); XmlNode root = xmlDoc.SelectSingleNode("bookstore");//查找<bookstore> XmlElement xe1 = xmlDoc.CreateElement("book");//創建一個<book>節點 xe1.SetAttribute("genre", "李讚紅");//設置該節點genre屬性 xe1.SetAttribute("ISBN", "2-3631-4");//設置該節點ISBN屬性 XmlElement xesub1 = xmlDoc.CreateElement("title"); xesub1.InnerText = "CS從入門到精通";//設置文本節點 xe1.AppendChild(xesub1);//添加到<book>節點中 XmlElement xesub2 = xmlDoc.CreateElement("author"); xesub2.InnerText = "候捷"; xe1.AppendChild(xesub2); XmlElement xesub3 = xmlDoc.CreateElement("price"); xesub3.InnerText = "58.3"; xe1.AppendChild(xesub3); root.AppendChild(xe1);//添加到<bookstore>節點中 xmlDoc.Save("E:\\bookstore.xml");
修改後的xml文件為:
<?xml version="1.0" encoding="gb2312"?> <bookstore> <book genre="fantasy" ISBN="2-3631-4"> <title>Oberon's Legacy</title> <author>Corets, Eva</author> <price>5.95</price> </book> <book genre="李讚紅"ISBN="2-3631-4"> <title>CS從入門到精通</title> <author>候捷</author> <price>58.3</price> </book> </bookstore>
2、修改節點:將genre屬性值為“李讚紅“的節點的genre值改為“update李讚紅”,將該節點的子節點<author>的文本修改為“亞勝”。
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load("E:\\bookstore.xml");
XmlNodeList nodeList = xmlDoc.SelectSingleNode("bookstore").ChildNodes;//獲取bookstore節點的所有子節點
foreach (XmlNode xn in nodeList)//遍曆所有子節點
{
XmlElement xe = (XmlElement)xn;//將子節點類型轉換為XmlElement類型
if (xe.GetAttribute("genre") == "李讚紅")//如果genre屬性值為“李讚紅”
{
xe.SetAttribute("genre", "update李讚紅");//則修改該屬性為“update李讚紅”
XmlNodeList nls = xe.ChildNodes;//繼續獲取xe子節點的所有子節點
foreach (XmlNode xn1 in nls)//遍曆
{
XmlElement xe2 = (XmlElement)xn1;//轉換類型
//title、author、price都會在xe2.Name中取到
if (xe2.Name == "author")//如果找到
{
xe2.InnerText = "亞勝";//則修改
break;//找到退出來就可以了
}
}
break;
}
}
xmlDoc.Save("bookstore.xml");//保存。
小注:
1、去掉修改節點代碼中的兩個break後,該代碼可以實現遍曆修改整個xml文檔的功能,由此可見foreach對於操作XML文件,可以進行遍曆的修改,但不能進行遍曆的增加與刪除。
<?xml version="1.0" encoding="gb2312"?> <bookstore> <book genre="fantasy" ISBN="2-3631-4"> <title>Oberon's Legacy</title> <author>Corets, Eva</author> <price>5.95</price> </book> <book genre="update李讚紅" ISBN="2-3631-4"> <title>CS從入門到精通</title> <author>亞勝</author> <price>58.3</price> </book> </bookstore>
3、刪除 <bookgenre="fantasy" ISBN="2-3631-4">節點的genre屬性,刪除 <bookgenre="update李讚紅" ISBN="2-3631-4">節點。
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load("E:\\bookstore.xml");
XmlNodeList xnl = xmlDoc.SelectSingleNode("bookstore").ChildNodes;
foreach (XmlNode xn in xnl)
{
XmlElement xe = (XmlElement)xn;
if (xe.GetAttribute("genre") == "fantasy")
{
xe.RemoveAttribute("genre");//刪除genre屬性
}
else if (xe.GetAttribute("genre") == "李讚紅")
{
//RemoveAll會移除指定節點下所有信息,但會保留該節點
xe.RemoveAll();//刪除該節點的全部內容
}
}
xmlDoc.Save("E:\\bookstore.xml");
小注:在操作XML文件的時候使用了foreach,故刪除一個節點的全部內容後,便會跳出foreach循環。
修改後的xml文件為:
<?xml version="1.0" encoding="gb2312"?> <bookstore> <book ISBN="2-3631-4"> <title>Oberon's Legacy</title> <author>Corets, Eva</author> <price>5.95</price> </book> <book> </book> </bookstore>4、顯示所有數據。
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load("E:\\bookstore.xml");
XmlNode xn = xmlDoc.SelectSingleNode("bookstore");
XmlNodeList xnl = xn.ChildNodes;
foreach (XmlNode xnf in xnl)
{
XmlElement xe = (XmlElement)xnf;
MessageBox.Show(xe.GetAttribute("genre"));//顯示屬性值
MessageBox.Show(xe.GetAttribute("ISBN"));
XmlNodeList xnf1 = xe.ChildNodes;
foreach (XmlNode xn2 in xnf1)
{
MessageBox.Show(xn2.InnerText);//顯示子節點點文本
}
}
原文地址==》
最後更新:2017-04-03 12:54:19