天天看點

在C#.net中如何操作XML

在C#.net中如何操作XML

 需要添加的命名空間:

 using System.Xml;

定義幾個公共對象:

 XmlDocument xmldoc ;

 XmlNode xmlnode ;

 XmlElement xmlelem ;

1,建立到伺服器同名目錄下的xml檔案:

方法一:

 xmldoc = new XmlDocument ( ) ;

 //加入XML的聲明段落,<?xml version="1.0" encoding="gb2312"?>

 XmlDeclaration xmldecl;

  xmldecl = xmldoc.CreateXmlDeclaration("1.0","gb2312",null);

  xmldoc.AppendChild ( xmldecl);

//加入一個根元素

 xmlelem = xmldoc.CreateElement ( "" , "Employees" , "" ) ;

 xmldoc.AppendChild ( xmlelem ) ;

 //加入另外一個元素

 for(int i=1;i<3;i++)

 {

XmlNode root=xmldoc.SelectSingleNode("Employees");//查找<Employees> 

XmlElement xe1=xmldoc.CreateElement("Node");//建立一個<Node>節點 

xe1.SetAttribute("genre","李贊紅");//設定該節點genre屬性 

xe1.SetAttribute("ISBN","2-3631-4");//設定該節點ISBN屬性 

XmlElement xesub1=xmldoc.CreateElement("title"); 

xesub1.InnerText="CS從入門到精通";//設定文本節點 

xe1.AppendChild(xesub1);//添加到<Node>節點中 

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);//添加到<Employees>節點中 

}

 //儲存建立好的XML文檔

 xmldoc.Save ( Server.MapPath("data.xml") ) ; 

//////////////////////////////////////////////////////////////////////////////////////

 結果:在同名目錄下生成了名為data.xml的檔案,内容如下,

 <?xml version="1.0" encoding="gb2312"?>

 <Employees>

   <Node genre="李贊紅" ISBN="2-3631-4">

     <title>CS從入門到精通</title>

     <author>候捷</author>

     <price>58.3</price>

   </Node>

 </Employees>

方法二:

 XmlTextWriter xmlWriter;

    string strFilename = Server.MapPath("data1.xml") ;

   xmlWriter = new XmlTextWriter(strFilename,Encoding.Default);//建立一個xml文檔

    xmlWriter.Formatting = Formatting.Indented;

    xmlWriter.WriteStartDocument();

    xmlWriter.WriteStartElement("Employees");

   xmlWriter.WriteStartElement("Node");

    xmlWriter.WriteAttributeString("genre","李贊紅");

    xmlWriter.WriteAttributeString("ISBN","2-3631-4");

   xmlWriter.WriteStartElement("title");

    xmlWriter.WriteString("CS從入門到精通");

    xmlWriter.WriteEndElement();

   xmlWriter.WriteStartElement("author");

    xmlWriter.WriteString("候捷");

   xmlWriter.WriteStartElement("price");

    xmlWriter.WriteString("58.3");

   xmlWriter.WriteEndElement();

   xmlWriter.Close();

 //////////////////////////////////////////////////////////////////////////////////////

 結果:

2,添加一個結點:

XmlDocument xmlDoc=new XmlDocument(); 

xmlDoc.Load(Server.MapPath("data.xml")); 

XmlNode root=xmlDoc.SelectSingleNode("Employees");//查找<Employees> 

XmlElement xe1=xmlDoc.CreateElement("Node");//建立一個<Node>節點 

xe1.SetAttribute("genre","張三");//設定該節點genre屬性 

xe1.SetAttribute("ISBN","1-1111-1");//設定該節點ISBN屬性 

XmlElement xesub1=xmlDoc.CreateElement("title"); 

xesub1.InnerText="C#入門幫助";//設定文本節點 

XmlElement xesub2=xmlDoc.CreateElement("author"); 

xesub2.InnerText="高手"; 

XmlElement xesub3=xmlDoc.CreateElement("price"); 

xesub3.InnerText="158.3"; 

xmlDoc.Save ( Server.MapPath("data.xml") );

 結果:在xml原有的内容裡添加了一個結點,内容如下,

   <Node genre="張三" ISBN="1-1111-1">

     <title>C#入門幫助</title>

     <author>高手</author>

     <price>158.3</price>

3,修改結點的值(屬性和子結點):

xmlDoc.Load( Server.MapPath("data.xml") ); 

XmlNodeList nodeList=xmlDoc.SelectSingleNode("Employees").ChildNodes;//擷取Employees節點的所有子節點 

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="亞勝";//則修改

 } 

xmlDoc.Save( Server.MapPath("data.xml") );//儲存。

 結果:将原來的所有結點的資訊都修改了,xml的内容如下,

   <Node genre="update張三" ISBN="1-1111-1">

     <author>亞勝</author>

4,修改結點(添加結點的屬性和添加結點的自結點):

 XmlDocument xmlDoc=new XmlDocument(); 

foreach(XmlNode xn in nodeList) 

XmlElement xe=(XmlElement)xn; 

xe.SetAttribute("test","111111");

XmlElement xesub=xmlDoc.CreateElement("flag"); 

xesub.InnerText="1"; 

xe.AppendChild(xesub); 

xmlDoc.Save( Server.MapPath("data.xml") );

 結果:每個結點的屬性都添加了一個,子結點也添加了一個,内容如下,

   <Node genre="李贊紅" ISBN="2-3631-4" test="111111">

     <flag>1</flag>

   <Node genre="update張三" ISBN="1-1111-1" test="111111">

5,删除結點中的某一個屬性:

XmlNodeList xnl=xmlDoc.SelectSingleNode("Employees").ChildNodes; 

foreach(XmlNode xn in xnl) 

xe.RemoveAttribute("genre");//删除genre屬性 

if(xe2.Name=="flag")//如果找到 

xe.RemoveChild(xe2);//則删除

xmlDoc.Save( Server.MapPath("data.xml") ); 

//////////////////////////////////////////////////////////////////////////////////////]

 結果:删除了結點的一個屬性和結點的一個子結點,内容如下,

   <Node ISBN="2-3631-4" test="111111">

   <Node ISBN="1-1111-1" test="111111">

6,删除結點:

XmlNode root=xmlDoc.SelectSingleNode("Employees");

 XmlNodeList xnl=xmlDoc.SelectSingleNode("Employees").ChildNodes; 

for(int i=0;i<xnl.Count;i++)

 XmlElement xe=(XmlElement)xnl.Item(i); 

if(xe.GetAttribute("genre")=="張三") 

root.RemoveChild(xe);

 if(i<xnl.Count)i=i-1;

 xmlDoc.Save( Server.MapPath("data.xml") ); 

 結果:删除了符合條件的所有結點,原來的内容:

<?xml version="1.0" encoding="gb2312"?>

删除後的内容:

 7,按照文本檔案讀取xml

System.IO.StreamReader myFile =new 

 System.IO.StreamReader(Server.MapPath("data.xml"),System.Text.Encoding.Default);

 //注意System.Text.Encoding.Default

string myString = myFile.ReadToEnd();//myString是讀出的字元串

 myFile.Close();