在C#.net中如何操作XML

需要添加的命名空间:
using System.Xml;

定义几个公共对象:
XmlDocument xmldoc ;
XmlNode xmlnode ;
XmlElement xmlelem ;

1,创建到服务器同名目录下的xml文件:
方法一:

  1. xmldoc = new XmlDocument ( ) ;
  2. //加入XML的声明段落,
  3. XmlDeclaration xmldecl;
  4.  xmldecl = xmldoc.CreateXmlDeclaration("1.0","gb2312",null);
  5.  xmldoc.AppendChild ( xmldecl);

  6. //加入一个根元素
  7. xmlelem = xmldoc.CreateElement ( "" , "Employees" , "" ) ;
  8. xmldoc.AppendChild ( xmlelem ) ;
  9. //加入另外一个元素
  10. for(int i=1;i<3;i++)
  11. {

  12. XmlNode root=xmldoc.SelectSingleNode("Employees");//查找 
  13. XmlElement xe1=xmldoc.CreateElement("Node");//创建一个节点 
  14. xe1.SetAttribute("genre","李赞红");//设置该节点genre属性 
  15. xe1.SetAttribute("ISBN","2-3631-4");//设置该节点ISBN属性 

  16. XmlElement xesub1=xmldoc.CreateElement("title"); 
  17. xesub1.InnerText="CS从入门到精通";//设置文本节点 
  18. xe1.AppendChild(xesub1);//添加到节点中 
  19. XmlElement xesub2=xmldoc.CreateElement("author"); 
  20. xesub2.InnerText="候捷"
  21. xe1.AppendChild(xesub2); 
  22. XmlElement xesub3=xmldoc.CreateElement("price"); 
  23. xesub3.InnerText="58.3"
  24. xe1.AppendChild(xesub3); 

  25. root.AppendChild(xe1);//添加到节点中 
  26. }
  27. //保存创建好的XML文档
  28. xmldoc.Save ( Server.MapPath("data.xml") ) ; 
//////////////////////////////////////////////////////////////////////////////////////
结果:在同名目录下生成了名为data.xml的文件,内容如下,
  1. "1.0" encoding="gb2312"?>
  2.   "李赞红" ISBN="2-3631-4">
  3.     CS从入门到精通
  4.     候捷
  5.     58.3
  6.   
  7.   "李赞红" ISBN="2-3631-4">
  8.     CS从入门到精通
  9.     候捷
  10.     58.3
  11.   
方法二:
  1. XmlTextWriter xmlWriter;
  2.    string strFilename = Server.MapPath("data1.xml") ;

  3.    xmlWriter = new XmlTextWriter(strFilename,Encoding.Default);//创建一个xml文档
  4.    xmlWriter.Formatting = Formatting.Indented;
  5.    xmlWriter.WriteStartDocument();
  6.    xmlWriter.WriteStartElement("Employees");

  7.    xmlWriter.WriteStartElement("Node");
  8.    xmlWriter.WriteAttributeString("genre","李赞红");
  9.    xmlWriter.WriteAttributeString("ISBN","2-3631-4");

  10.    xmlWriter.WriteStartElement("title");
  11.    xmlWriter.WriteString("CS从入门到精通");
  12.    xmlWriter.WriteEndElement();

  13.    xmlWriter.WriteStartElement("author");
  14.    xmlWriter.WriteString("候捷");
  15.    xmlWriter.WriteEndElement();

  16.    xmlWriter.WriteStartElement("price");
  17.    xmlWriter.WriteString("58.3");
  18.    xmlWriter.WriteEndElement();

  19.    xmlWriter.WriteEndElement();

  20.    xmlWriter.Close();
//////////////////////////////////////////////////////////////////////////////////////
结果:
  1. "1.0" encoding="gb2312"?>
  2.   "李赞红" ISBN="2-3631-4">
  3.     CS从入门到精通
  4.     候捷
  5.     58.3
  6.   
2,添加一个结点:
  1. XmlDocument xmlDoc=new XmlDocument(); 
  2. xmlDoc.Load(Server.MapPath("data.xml")); 
  3. XmlNode root=xmlDoc.SelectSingleNode("Employees");//查找 
  4. XmlElement xe1=xmlDoc.CreateElement("Node");//创建一个节点 
  5. xe1.SetAttribute("genre","张三");//设置该节点genre属性 
  6. xe1.SetAttribute("ISBN","1-1111-1");//设置该节点ISBN属性 

  7. XmlElement xesub1=xmlDoc.CreateElement("title"); 
  8. xesub1.InnerText="C#入门帮助";//设置文本节点 
  9. xe1.AppendChild(xesub1);//添加到节点中 
  10. XmlElement xesub2=xmlDoc.CreateElement("author"); 
  11. xesub2.InnerText="高手"
  12. xe1.AppendChild(xesub2); 
  13. XmlElement xesub3=xmlDoc.CreateElement("price"); 
  14. xesub3.InnerText="158.3"
  15. xe1.AppendChild(xesub3); 

  16. root.AppendChild(xe1);//添加到节点中 
  17. xmlDoc.Save ( Server.MapPath("data.xml") );
//////////////////////////////////////////////////////////////////////////////////////
结果:在xml原有的内容里添加了一个结点,内容如下,
  1. "1.0" encoding="gb2312"?>
  2.   "李赞红" ISBN="2-3631-4">
  3.     CS从入门到精通
  4.     候捷
  5.     58.3
  6.   
  7.   "李赞红" ISBN="2-3631-4">
  8.     CS从入门到精通
  9.     候捷
  10.     58.3
  11.   
  12.   "张三" ISBN="1-1111-1">
  13.     C#入门帮助
  14.     高手
  15.     158.3
  16.   

3,修改结点的值(属性和子结点):
  1. XmlDocument xmlDoc=new XmlDocument(); 
  2. xmlDoc.Load( Server.MapPath("data.xml") ); 

  3. XmlNodeList nodeList=xmlDoc.SelectSingleNode("Employees").ChildNodes;//获取Employees节点的所有子节点 

  4. foreach(XmlNode xn in nodeList)//遍历所有子节点 
  5. XmlElement xe=(XmlElement)xn;//将子节点类型转换为XmlElement类型 
  6. if(xe.GetAttribute("genre")=="张三")//如果genre属性值为“张三” 
  7. xe.SetAttribute("genre","update张三");//则修改该属性为“update张三” 

  8. XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的所有子节点 
  9. foreach(XmlNode xn1 in nls)//遍历 
  10. XmlElement xe2=(XmlElement)xn1;//转换类型 
  11. if(xe2.Name=="author")//如果找到 
  12. xe2.InnerText="亚胜";//则修改
  13. xmlDoc.Save( Server.MapPath("data.xml") );//保存。

//////////////////////////////////////////////////////////////////////////////////////
结果:将原来的所有结点的信息都修改了,xml的内容如下,
  1. xml version="1.0" encoding="gb2312"?>
  2. <Employees>
  3.   <Node genre="李赞红" ISBN="2-3631-4">
  4.     <title>CS从入门到精通title>
  5.     <author>候捷author>
  6.     <price>58.3price>
  7.   Node>
  8.   <Node genre="李赞红" ISBN="2-3631-4">
  9.     <title>CS从入门到精通title>
  10.     <author>候捷author>
  11.     <price>58.3price>
  12.   Node>
  13.   <Node genre="update张三" ISBN="1-1111-1">
  14.     <title>C#入门帮助title>
  15.     <author>亚胜author>
  16.     <price>158.3price>
  17.   Node>
  18. Employees>

4,修改结点(添加结点的属性和添加结点的自结点):
  1. XmlDocument xmlDoc=new XmlDocument(); 
  2. xmlDoc.Load( Server.MapPath("data.xml") ); 

  3. XmlNodeList nodeList=xmlDoc.SelectSingleNode("Employees").ChildNodes;//获取Employees节点的所有子节点 

  4. foreach(XmlNode xn in nodeList) 
  5. XmlElement xe=(XmlElement)xn; 
  6. xe.SetAttribute("test","111111");

  7. XmlElement xesub=xmlDoc.CreateElement("flag"); 
  8. xesub.InnerText="1"
  9. xe.AppendChild(xesub); 
  10. xmlDoc.Save( Server.MapPath("data.xml") );
//////////////////////////////////////////////////////////////////////////////////////
结果:每个结点的属性都添加了一个,子结点也添加了一个,内容如下,
  1. xml version="1.0" encoding="gb2312"?>
  2. <Employees>
  3.   <Node genre="李赞红" ISBN="2-3631-4" test="111111">
  4.     <title>CS从入门到精通title>
  5.     <author>候捷author>
  6.     <price>58.3price>
  7.     <flag>1flag>
  8.   Node>
  9.   <Node genre="李赞红" ISBN="2-3631-4" test="111111">
  10.     <title>CS从入门到精通title>
  11.     <author>候捷author>
  12.     <price>58.3price>
  13.     <flag>1flag>
  14.   Node>
  15.   <Node genre="update张三" ISBN="1-1111-1" test="111111">
  16.     <title>C#入门帮助title>
  17.     <author>亚胜author>
  18.     <price>158.3price>
  19.     <flag>1flag>
  20.   Node>
  21. Employees>
5,删除结点中的某一个属性:
  1. XmlDocument xmlDoc=new XmlDocument(); 
  2. xmlDoc.Load( Server.MapPath("data.xml") ); 
  3. XmlNodeList xnl=xmlDoc.SelectSingleNode("Employees").ChildNodes; 
  4. foreach(XmlNode xn in xnl) 
  5. XmlElement xe=(XmlElement)xn; 
  6. xe.RemoveAttribute("genre");//删除genre属性 

  7. XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的所有子节点 
  8. foreach(XmlNode xn1 in nls)//遍历 
  9. XmlElement xe2=(XmlElement)xn1;//转换类型 
  10. if(xe2.Name=="flag")//如果找到 
  11. xe.RemoveChild(xe2);//则删除
  12. xmlDoc.Save( Server.MapPath("data.xml") ); 
//////////////////////////////////////////////////////////////////////////////////////]
结果:删除了结点的一个属性和结点的一个子结点,内容如下,
  1. xml version="1.0" encoding="gb2312"?>
  2. <Employees>
  3.   <Node ISBN="2-3631-4" test="111111">
  4.     <title>CS从入门到精通title>
  5.     <author>候捷author>
  6.     <price>58.3price>
  7.   Node>
  8.   <Node ISBN="2-3631-4" test="111111">
  9.     <title>CS从入门到精通title>
  10.     <author>候捷author>
  11.     <price>58.3price>
  12.   Node>
  13.   <Node ISBN="1-1111-1" test="111111">
  14.     <title>C#入门帮助title>
  15.     <author>亚胜author>
  16.     <price>158.3price>
  17.   Node>
  18. Employees>
6,删除结点:
  1. XmlDocument xmlDoc=new XmlDocument(); 
  2. xmlDoc.Load( Server.MapPath("data.xml") ); 
  3. XmlNode root=xmlDoc.SelectSingleNode("Employees");
  4. XmlNodeList xnl=xmlDoc.SelectSingleNode("Employees").ChildNodes; 
  5. for(int i=0;i
  6. {
  7. XmlElement xe=(XmlElement)xnl.Item(i); 
  8. if(xe.GetAttribute("genre")=="张三"
  9. root.RemoveChild(xe);
  10. if(i
  11. }
  12. xmlDoc.Save( Server.MapPath("data.xml") ); 
//////////////////////////////////////////////////////////////////////////////////////]
结果:删除了符合条件的所有结点,原来的内容:
  1. xml version="1.0" encoding="gb2312"?>
  2. <Employees>
  3.   <Node genre="李赞红" ISBN="2-3631-4">
  4.     <title>CS从入门到精通title>
  5.     <author>候捷author>
  6.     <price>58.3price>
  7.   Node>
  8.   <Node genre="李赞红" ISBN="2-3631-4">
  9.     <title>CS从入门到精通title>
  10.     <author>候捷author>
  11.     <price>58.3price>
  12.   Node>
  13.   <Node genre="张三" ISBN="1-1111-1">
  14.     <title>C#入门帮助title>
  15.     <author>高手author>
  16.     <price>158.3price>
  17.   Node>
  18.   <Node genre="张三" ISBN="1-1111-1">
  19.     <title>C#入门帮助title>
  20.     <author>高手author>
  21.     <price>158.3price>
  22.   Node>
  23. Employees>

删除后的内容:
  1. xml version="1.0" encoding="gb2312"?>
  2. <Employees>
  3.   <Node genre="李赞红" ISBN="2-3631-4">
  4.     <title>CS从入门到精通title>
  5.     <author>候捷author>
  6.     <price>58.3price>
  7.   Node>
  8.   <Node genre="李赞红" ISBN="2-3631-4">
  9.     <title>CS从入门到精通title>
  10.     <author>候捷author>
  11.     <price>58.3price>
  12.   Node>
  13. Employees>
 7,按照文本文件读取xml
  1. System.IO.StreamReader myFile =new 
  2. System.IO.StreamReader(Server.MapPath("data.xml"),System.Text.Encoding.Default);
  3. //注意System.Text.Encoding.Default

  4. string myString = myFile.ReadToEnd();//myString是读出的字符串
  5. myFile.Close();

你可能感兴趣的:(.Net,Asp.Net,C#,encoding,xml,文档,服务器,c#,null)