閱讀700 返回首頁    go 阿裏雲 go 技術社區[雲棲]


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文件,可以進行遍曆的修改,但不能進行遍曆的增加與刪除。
2、注意對於xml文件操作中for與foreach的對應轉化:關於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="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

  上一篇:go System.InvalidOperationException: 集合已修改;可能無法執行枚舉操作。
  下一篇:go Convert、Parse、TryParse、(int) 的區別