zoukankan      html  css  js  c++  java
  • C#操作XML方法详解

    C#操作XML方法详解

    using System.Xml;
    //初始化一个xml实例
    XmlDocument xml=new XmlDocument();

    //导入指定xml文件
    xml.Load(path);
    xml.Load(HttpContext.Current.Server.MapPath("~/file/bookstore.xml"));

    //指定一个节点
    XmlNode root=xml.SelectSingleNode("/root");

    //获取节点下所有直接子节点
    XmlNodeList childlist=root.ChildNodes;

    //判断该节点下是否有子节点
    root.HasChildNodes;

    //获取同名同级节点集合
    XmlNodeList nodelist=xml.SelectNodes("/Root/News");

    //生成一个新节点
    XmlElement node=xml.CreateElement("News");

    //将节点加到指定节点下,作为其子节点
    root.AppendChild(node);

    //将节点加到指定节点下某个子节点前
    root.InsertBefore(node,root.ChildeNodes[i]);

    //为指定节点的新建属性并赋值
    node.SetAttribute("id","11111");

    //为指定节点添加子节点
    root.AppendChild(node);

    //获取指定节点的指定属性值
    string id=node.Attributes["id"].Value;

    //获取指定节点中的文本
    string content=node.InnerText;

    //保存XML文件
    string path=Server.MapPath("~/file/bookstore.xml");
    xml.Save(path);
    //or use :xml.Save(HttpContext.Current.Server.MapPath("~/file/bookstore.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>
      <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")); 
    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#入门帮助";//设置文本节点 
    xe1.AppendChild(xesub1);//添加到<Node>节点中 
    XmlElement xesub2=xmlDoc.CreateElement("author"); 
    xesub2.InnerText="高手"; 
    xe1.AppendChild(xesub2); 
    XmlElement xesub3=xmlDoc.CreateElement("price"); 
    xesub3.InnerText="158.3"; 
    xe1.AppendChild(xesub3);

    root.AppendChild(xe1);//添加到<Employees>节点中 
    xmlDoc.Save ( Server.MapPath("data.xml") );

    //////////////////////////////////////////////////////////////////////////////////////
    结果:在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>
      <Node genre="张三" ISBN="1-1111-1">
        <title>C#入门帮助</title>
        <author>高手</author>
        <price>158.3</price>
      </Node>
    </Employees>

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

    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="亚胜";//则修改




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

    //////////////////////////////////////////////////////////////////////////////////////
    结果:将原来的所有结点的信息都修改了,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>
      <Node genre="update张三" ISBN="1-1111-1">
        <title>C#入门帮助</title>
        <author>亚胜</author>
        <price>158.3</price>
      </Node>
    </Employees>

    4,修改结点(添加结点的属性和添加结点的自结点):
    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; 
    xe.SetAttribute("test","111111");

    XmlElement xesub=xmlDoc.CreateElement("flag"); 
    xesub.InnerText="1"; 
    xe.AppendChild(xesub); 

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

    //////////////////////////////////////////////////////////////////////////////////////
    结果:每个结点的属性都添加了一个,子结点也添加了一个,内容如下,
    <?xml version="1.0" encoding="gb2312"?>
    <Employees>
      <Node genre="李赞红" ISBN="2-3631-4" test="111111">
        <title>CS从入门到精通</title>
        <author>候捷</author>
        <price>58.3</price>
        <flag>1</flag>
      </Node>
      <Node genre="李赞红" ISBN="2-3631-4" test="111111">
        <title>CS从入门到精通</title>
        <author>候捷</author>
        <price>58.3</price>
        <flag>1</flag>
      </Node>
      <Node genre="update张三" ISBN="1-1111-1" test="111111">
        <title>C#入门帮助</title>
        <author>亚胜</author>
        <price>158.3</price>
        <flag>1</flag>
      </Node>
    </Employees>

    5,删除结点中的某一个属性:
    XmlDocument xmlDoc=new XmlDocument(); 
    xmlDoc.Load( Server.MapPath("data.xml") ); 
    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);//则删除



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

    //////////////////////////////////////////////////////////////////////////////////////]
    结果:删除了结点的一个属性和结点的一个子结点,内容如下,
    <?xml version="1.0" encoding="gb2312"?>
    <Employees>
      <Node ISBN="2-3631-4" test="111111">
        <title>CS从入门到精通</title>
        <author>候捷</author>
        <price>58.3</price>
      </Node>
      <Node ISBN="2-3631-4" test="111111">
        <title>CS从入门到精通</title>
        <author>候捷</author>
        <price>58.3</price>
      </Node>
      <Node ISBN="1-1111-1" test="111111">
        <title>C#入门帮助</title>
        <author>亚胜</author>
        <price>158.3</price>
      </Node>
    </Employees>

    6,删除结点:
    XmlDocument xmlDoc=new XmlDocument(); 
    xmlDoc.Load( Server.MapPath("data.xml") ); 
    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"?>
    <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>
      <Node genre="张三" ISBN="1-1111-1">
        <title>C#入门帮助</title>
        <author>高手</author>
        <price>158.3</price>
      </Node>
      <Node genre="张三" ISBN="1-1111-1">
        <title>C#入门帮助</title>
        <author>高手</author>
        <price>158.3</price>
      </Node>
    </Employees>

    删除后的内容:
    <?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>

     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();

    三、高级应用 

    /*读取xml数据   两种xml方式*/
    <aaa>
         <bb>something</bb>
         <cc>something</cc>
    </aaa>
     
    <aaa>
        <add key="123" value="321"/>
    </aaa>

    /*第一种方法*/
    DS.ReadXml("your xmlfile name");
    Container.DataItem("bb");
    Container.DataItem("cc");
    DS.ReadXmlSchema("your xmlfile name");
     
    /*第二种方法*/
    <aaa>
        <add key="123" value="321"/>
    </aaa>
    如果我要找到123然后取到321应该怎么写呢?
     
    using System.XML;
    XmlDataDocument xmlDoc = new System.Xml.XmlDataDocument();
    xmlDoc.Load(@"c:/Config.xml");
    XmlElement elem = xmlDoc.GetElementById("add");
    string str = elem.Attributes["value"].Value
     
     
    /*第三种方法:  SelectSingleNode  读取两种格式的xml *---/
    --------------------------------------------------------------------
    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
        <appSettings>
           <ConnectionString>Data Source=yf; user id=ctm_dbo;password=123</ConnectionString>             
      </appSettings>
    </configuration>
    --------------------------------------------------------------------------
    XmlDocument doc = new XmlDocument();
    doc.Load(strXmlName);
     
        XmlNode node=doc.SelectSingleNode("/configuration/appSettings/ConnectionString");
        if(node!=null)
        {
         string k1=node.Value;    //null
         string k2=node.InnerText;//Data Source=yf; user id=ctm_dbo;password=123
         string k3=node.InnerXml;//Data Source=yf; user id=ctm_dbo;password=123
         node=null;
        }
     
    ********************************************************************
    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
        <appSettings>
           <add key="ConnectionString" value="Data Source=yf; user id=ctm_dbo;password=123" />             
      </appSettings>
    </configuration>
    **--------------------------------------------------------------------**
         XmlNode node=doc.SelectSingleNode("/configuration/appSettings/add");
        if(node!=null)
        {
         string k=node.Attributes["key"].Value;
         string v=node.Attributes["value"].Value;
         node=null;
        }
    *--------------------------------------------------------------------*
        XmlNode node=doc.SelectSingleNode("/configuration/appSettings/add");
        if(node!=null)
        {
         XmlNodeReader nr=new XmlNodeReader(node);
         nr.MoveToContent();
        //检查当前节点是否是内容节点。如果此节点不是内容节点,则读取器向前跳至下一个内容节点或文件结尾。
         nr.MoveToAttribute("value");
         string s=nr.Value;
         node=null;
        }

    尊重作者,转发请注明出处:http://www.cnblogs.com/minotmin
    谢谢阅读,有错请指出,不甚感激。

  • 相关阅读:
    韩式英语
    Daily dictation 听课笔记
    words with same pronunciation
    you will need to restart eclipse for the changes to take effect. would you like to restart now?
    glottal stop(britain fountain mountain)
    education 的发音
    第一次用Matlab 的lamada语句
    SVN的switch命令
    String的split
    SVN模型仓库中的资源从一个地方移动到另一个地方的办法(很久才解决)
  • 原文地址:https://www.cnblogs.com/lonelyofsoul/p/xml.html
Copyright © 2011-2022 走看看