XML文件一般读写操作

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

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

方法一:

XmlDocument xmldoc = new XmlDocument ( ) ;
XmlDeclaration xmldecl;
xmldecl 
= xmldoc.CreateXmlDeclaration("1.0","gb2312",null);//加入XML的声明段落,<?xml version="1.0" encoding="gb2312"?>
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>节点中
}

xmldoc.Save ( Server.MapPath(
"data.xml") ) ;//保存创建好的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>
  <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.WriteEndElement();
xmlWriter.WriteStartElement(
"price");
xmlWriter.WriteString(
"58.3");
xmlWriter.WriteEndElement();
xmlWriter.WriteEndElement();
xmlWriter.Close();

结果:
<?xml version="1.0" encoding="gb2312"?>
<Employees>
  <Node genre="李赞红" ISBN="2-3631-4">
    <title>CS从入门到精通</title>
    <author>候捷</author>
    <price>58.3</price>
  </Node>
</Employees>

2,修改结点的值(属性和子结点):

 

XmlDocument xmlDoc=new XmlDocument();
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
="亚胜";   //则修改
   }

  }

 }

 
}
//修改属性添加节点
XmlNodeList nodeList=xmlDoc.SelectSingleNode("Employees").ChildNodes;//获取Employees节点的所有子节点
foreach(XmlNode xn in nodeList)
{
 XmlElement xe
=(XmlElement)xn;
 xe.SetAttribute(
"test","111111");//修改该属性
 
 XmlElement xesub
=xmlDoc.CreateElement("flag");
 xesub.InnerText
="1";
 xe.AppendChild(xesub);
}

//删除属性和节点
XmlNodeList xnl=xmlDoc.SelectSingleNode("Employees").ChildNodes;
foreach(XmlNode xn in xnl)
{
 XmlElement xe
=(XmlElement)xn;
 xe.RemoveAttribute(
"genre");//删除genre属性
 
 XmlNodeList nls
=xe.ChildNodes;//继续获取xe子节点的所有子节点
 foreach(XmlNode xn1 in nls)//遍历
 {
  XmlElement xe2
=(XmlElement)xn1;//转换类型
  if(xe2.Name=="flag")//如果找到
  {
   xe.RemoveChild(xe2);
//则删除
  }

 }

}


//删除结点
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") );  //保存。

3,按照文本文件读取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();
posted @ 2008-04-01 17:23  大力哥的技术  阅读(333)  评论(1)    收藏  举报
版权
作者:Bober Song

出处:http://bober.cnblogs.com

Care健康:http://www.aicareyou.com

推荐空间:华夏名网

本文首发博客园,版权归作者跟博客园共有。

转载必须保留本段声明,并在页面显著位置给出本文链接,否则保留追究法律责任的权利。