已知有一个xml文件(bookstore.xml)如下: <?xml version="1.0" encoding="gb2312"?> <bookstore> <book genre="fantasy" ISBN="2-3631-4"> <title>Oberon's Legacy</title> <author>。
 

已知有一个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);//显示子节点点文本   
          }   
        }

[责任编辑:qqread.com/巧巧豆]

相关文章:VC++中利用MSXML解析XML文档

这种对象模型实现的基本功能包括:·描述文档表示和操作的接口; · 接口的行为和属性;· 接口之间的关系以及互操作。一、 xml 简介XML(Xtensible Markup Language,即扩展标记语言)的发展起源于1996年。DTD和XML大纲规定了XML文件的逻辑结构,定义了XML文件中的元素、元素的属性以及元素与元素属性之间的关系。

C#中操作xml文件(插入节点、修改、删除)的更多相关文章

  1. C#中读取xml文件指定节点

    目录(?)[-] XmlDocumentSelectSingleNode方法的使用 XmlDocumentSelectNodes方法的使用 通过节点属性查找指定节点   参考:Select XML N ...

  2. Java代码操作properties文件(读取,新增/修改,删除)

    项目中需要用到操作properties文件中的数据,记录一下 package com.bonc.savepic.save; import java.io.FileNotFoundException; ...

  3. C#中操作XML文件

    1.添加结点:XmlNode xmldoc.Load("..\\..\\App.config"); //根元素 XmlElement root = xmldoc.DocumentE ...

  4. C#.Net中操作XML方法一

    我们知道XML是一种可标记性的语言,用来标记数据.定义数据类型,是一种执行用户对自己的标记语言进行定义的源语言.由于结构好.而且easy理解,就好比一棵树,层次关系分明,因此也经常把一些数据存储到XM ...

  5. java操作xml文件--修改节点

          上一篇文章我介绍了SAX方法解析XML文件的过程,这篇文章讲解的内容是利用DOM方法修改XML文件的节点内容.       下面依然是首先贴出XML文件: <?xml version ...

  6. JAVA中通过Jaxp操作XML文件基础

    Java中有多种方式操作XML文件,目前讲一讲以SUN公司提供的DocumentBuilderFactory工厂类对象操作XML. 使用XML基本操作就是需要CRUD(增删改查),那么首先通过一个查询 ...

  7. 修改Android中strings.xml文件, 动态改变数据

    有些朋友可能会动态的修改Android中strings.xml文件中的值,在这里给大家推荐一种简单的方法.strings.xml中节点是支持占位符的,如下所示: <string name=&qu ...

  8. php操作xml并插入到数据库中

    php操作xml并插入到数据库中 <? php header('content-type:text/html;charset=utf-8'); mysql_connect('localhost' ...

  9. opencv局限:cv::FileStorage读取中,xml文件的第一层节点不能超过4个

    今天测试发现一个问题,cv::FileStorage读取中,xml文件的第一层节点不能超过4个. <?xml version="1.0"?> <opencv_st ...

随机推荐

  1. Linux CentOS6.x ip设置(网卡设置)

    修改IP永久生效按以下方法vi /etc/sysconfig/network-scripts/ifcfg-eth0(eth0,第一块网卡,如果是第二块则为eth1)按如下修改ip: DEVICE=et ...

  2. ASP.NET MVC Ajax.ActionLink 简单用法

    ASP.NET MVC 项目中,如何使用类似于 iframe 的效果呢?或者说 Ajax 局部刷新,比如下面操作: 我们想要的效果是,点击 About 链接,页面不刷新(地址栏不变),然后下面的内容进 ...

  3. ARM汇编与C混合编程

    GNU内联汇编 内联汇编即在C中直接使用汇编语句进行编程,使程序可以在C程序中实现C语言不能完成的一些工作,例如,在下面几种情况中必须使用内联汇编或嵌入型汇编 程序中使用饱和算术运算(Saturati ...

  4. Read Excel file from C#

    Common way is: var fileName = string.Format("{0}\\fileNameHere", Directory.GetCurrentDirec ...

  5. 无法卸载jdk的解决方法

    装了java之后非常纠结的就是无法卸载,总不能因为卸载一个jdk去重装系统,但是看着它残存在那又非常不爽, 因为卸载会牵扯注册表等琐碎的东西,,,后来在官网发现神器一枚,此神器就是java卸载工具. ...

  6. 【63测试20161111】【BFS】【DP】【字符串】

    第一题: tractor 题目描述 农场上有N(1 <= N <= 50,000)堆草,放在不同的地点上.FJ有一辆拖拉机,也在农场上.拖拉机和草堆都表示为二维平面上的整数坐标,坐标值在1 ...

  7. 获取DIV与浏览器顶部相聚一定位置之后移动DIV

    获取元素(这里定位元素A)距离顶部的高度,接着设定scroll滚动的事件,比如超过那个高度,把A的位置设定为fixed,小于该高度,修改回relative. 方法一: $(function() {  ...

  8. sqoop组件运行出错问题解决--com.mysql.jdbc.Driver

    sqoop list-tables --connect jdbc:mysql://192.168.11.94:3306/huochetoudalian --username xxx -password ...

  9. javascript (九)注释

    单行注释,采用双斜杠  // 多行注释,采用 /* */

  10. Java中常见数据结构List之ArrayList

    这里主要包含ArrayList和LinkedList, 然后再添加一个:CopyOnWriteArrayList 关于Java中的集合内容, 感觉都已经被写烂了, 我这里主要是做个复习, 再从扒下源代 ...