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