XML的簡單讀取與寫入

來源:互聯網
上載者:User
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("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("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> 
<book genre="李贊紅" ISBN="2-3631-4"> 
<title>CS從入門到精通</title> 
<author>候捷</author> 
<price>58.3</price> 
</book> 
</bookstore> 

2、修改節點:將genre屬性值為“李贊紅“的節點的genre值改為“update李贊紅”,將該節點的子節點<author>的文本修改為“亞勝”。 
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;//轉換類型 
if(xe2.Name=="author")//如果找到 

xe2.InnerText="亞勝";//則修改 
break;//找到退出來就可以了 


break; 



xmlDoc.Save("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> 
<book genre="update李贊紅" ISBN="2-3631-4"> 
<title>CS從入門到精通</title> 
<author>亞勝</author> 
<price>58.3</price> 
</book> 
</bookstore> 

3、刪除 <book genre="fantasy" ISBN="2-3631-4">節點的genre屬性,刪除 <book genre="update李贊紅" ISBN="2-3631-4">節點。 
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")=="update李贊紅") 

xe.RemoveAll();//刪除該節點的全部內容 


xmlDoc.Save("bookstore.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、顯示所有資料。 
XmlNode xn=xmlDoc.SelectSingleNode("bookstore"); 

XmlNodeList xnl=xn.ChildNodes; 

foreach(XmlNode xnf in xnl) 

XmlElement xe=(XmlElement)xnf; 
Console.WriteLine(xe.GetAttribute("genre"));//顯示內容值 
Console.WriteLine(xe.GetAttribute("ISBN")); 

XmlNodeList xnf1=xe.ChildNodes; 
foreach(XmlNode xn2 in xnf1) 

Console.WriteLine(xn2.InnerText);//顯示子節點點文本 



相關文章

Alibaba Cloud 10 Year Anniversary

With You, We are Shaping a Digital World, 2009-2019

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。