我把我写的四种方法代码贴上来吧,照着写没啥问题。

  注:

    <bookstore>
      <book>
        <Id>1</Id>
        <tate>2010-10-10</tate>
        <txt>123</txt>
        <yy>2015</yy>
        <dd>23</dd>
      </book>
    </bookstore>

  这是xml文件的目录结构。

    首先开始xml读取数据:

      XmlDocument doc = new XmlDocument();  //声明一个xml文件对象

       doc.Load(@"..\..\sb.xml");          //获取xml文件路径

       XmlNode xn = doc.SelectSingleNode("bookstore");  //获取xml文件根节点

       XmlNodeList xnl = xn.ChildNodes;          //获取子节点

      //循环子节点获取值
      foreach (XmlNode xn1 in xnl)
       {

        //声明一个对象,这个对象就是xml文件目录下的节点,声明一个对象用来接收xml文件数据
        Info i = new Info();
        // 将节点转换为元素,便于得到节点的属性值
        XmlElement xe = (XmlElement)xn1;
        // 得到Type和ISBN两个属性的属性值

        // 得到Book节点的所有子节点
        XmlNodeList xnl0 = xe.ChildNodes;

        //获取数据并且保存到list集合中(list集合是泛型集合)
        i.ID = xnl0.Item(0).InnerText;
        i.date = xnl0.Item(1).InnerText;
        i.txt = xnl0.Item(2).InnerText;
        i.yy = xnl0.Item(3).InnerText;
        i.dd = xnl0.Item(4).InnerText;
        list.Add(i);
        }

    添加xml数据:

      //声明一个要添加的xml数据对象  

      Info i = new Info();
      i.date = DateTime.Now.ToString();
      i.txt = txts.Text;
      i.yy = DateTime.Now.ToString();
      i.dd = DateTime.Now.ToString();
      i.ID = (list.Count + 1).ToString();

      声明一个xml对象
      XmlDocument doc = new XmlDocument();

      //获取xml文件路径

      doc.Load(@"..\..\sb.xml");

      //获取根节点

      XmlNode root = doc.SelectSingleNode("bookstore");

      //创建子节点

      XmlElement xelKey = doc.CreateElement("book");    

      //为子节点创建子节点
      XmlElement xmlid = doc.CreateElement("Id");
      xmlid.InnerText = i.ID;
      xelKey.AppendChild(xmlid);
      XmlElement xmldate = doc.CreateElement("date");
      xmldate.InnerText = i.date;
      //添加当前时间
      xelKey.AppendChild(xmldate);
      //创建文本节点
      XmlElement xmltxt = doc.CreateElement("txt");
      xmltxt.InnerText = i.txt;
      //添加当前文本框
      xelKey.AppendChild(xmltxt);

      //创建文本节点
      XmlElement xmlyy = doc.CreateElement("yy");
      xmlyy.InnerText = i.yy;
      //添加当前文本框
      xelKey.AppendChild(xmlyy);
      //创建文本节点
      XmlElement xmltdd = doc.CreateElement("dd");
      xmltdd.InnerText = i.dd;
      //添加当前文本框
      xelKey.AppendChild(xmltdd);

      //在根节点上添加子节点
      root.AppendChild(xelKey);
      //保存添加的数据(对xml文件进行增删改操作后,必须执行这个方法)
      doc.Save(@"..\..\sb.xml");

    修改xml数据:

      int  id ; //这是一个标示值,指在循环时,根据这个标示值来匹配修改的是哪一个节点

      txtUP.Text  //当前要修改数据的文本框值

      //声明一个xml对象

      XmlDocument xmlDoc = new XmlDocument();

      //获取xml路径
      xmlDoc.Load(@"..\..\sb.xml");

      //获取xml文件根节点
      XmlNode xns = xmlDoc.SelectSingleNode("bookstore");

      //获取子节点
      XmlNodeList xnl = xns.ChildNodes;

      //循环子节点
      foreach (XmlNode xn in xnl)
       {
        XmlElement xe = (XmlElement)xn;//将节点转换一下类型
       

        if (xe["Id"].InnerText == id)//判断该子节点是否是要查找的节点
          {

           //循环节点对象    

            foreach (XmlNode item in xe.ChildNodes)
              {
                if (item.Name == "txt")
                  {
                  item.InnerText = txtUP.Text;
                  xmlDoc.Save(@"..\..\sb.xml");//再一次强调 ,一定要记得保存的该XML文件
                  break;
                  }
                }

          }
        //若是当前节点下还有子节点如下操作
        //XmlNodeList xnl2 = xn.ChildNodes;//取出该子节点下面的所有元素
        //foreach (XmlNode xn2 in xnl2)
          //{
            // XmlElement xe2 = (XmlElement)xn2;//转换类型
            // if (xe2.Name == "price")//判断是否是要查找的元素
            // {
              //这里你就可以进行操作,是喜欢查找子节点还是在当前节点进行操作
            // }
          //}
          
        }
        xmlDoc.Save(@"..\..\sb.xml");////保存添加的数据(对xml文件进行增删改操作后,必须执行这个方法)

    删除xml节点包括数据:

      int id;  //标识值,用于判断删除那条数据  

      //声明一个xml对象
      XmlDocument xmldoc = new XmlDocument();
      //打开一个xml文件
      xmldoc.Load(@"..\..\sb.xml");
      //获取根节点
      XmlNode xnRoot = xmldoc.SelectSingleNode("bookstore");
      //获取根节点下的子节点
      XmlNodeList nodelist = xnRoot.ChildNodes;
      //循环所有子节点
      foreach (XmlNode node in nodelist)
       {
        //判断子节点的值是否为当前选中的那一项
        if (node.SelectSingleNode("Id").InnerXml == id)
         {
          //是的话则进行删除该节点
          xnRoot.RemoveChild(node);
          //保存xml文件操作
          xmldoc.Save(@"..\..\sb.xml");
         }
       }

    以上是我对xml文件的增删改查操作,若是好的建议或者代码有什么问题的,可以留言,我会参考你的意见的。

   

我来讲讲在c#中怎么进行xml文件操作吧,主要是讲解增删改查!的更多相关文章

  1. 数据库中的记录通过servlet回显到jsp页面中(连接数据库或者查询參照:对数据进行增删改查)

    我们常常会用到通过图书的名称来查询图书那么这种话我们也就会使用到从数据库中搜索出数据而且载入到自己的Jsp页面中 这种话我们须要将从数据库中获取到的数据放进响应中然后通过%=request.getAt ...

  2. Golang中map的三种声明方式和简单实现增删改查

    package main import ( "fmt" ) func main() { test3 := map[string]string{ "one": & ...

  3. flask中 多对多的关系 主从表之间的的增删改查

    # 角色表模型class Role(db.Model): r_id = db.Column(db.Integer, primary_key=True) r_name = db.Column(db.St ...

  4. C#在winform中操作数据库,实现数据增删改查

    1.前言: 运行环境:VS2013+SQL2008+Windows10 程序界面预览: 使用的主要控件:dataGridview和menuStrip等. 2.功能具体介绍: 1.首先,我们要先实现基本 ...

  5. 中阶d03.3 JDBC_CURD_Util --- 使用 junit执行单元测试(增删改查)

    1.单元测试环境准备 https://www.cnblogs.com/longesang/p/11399010.html 2.测试 3.结果返回 4.代码 新建一个test目录统一存放测试案例 查: ...

  6. MVC设计模式((javaWEB)在数据库连接池下,实现对数据库中的数据增删改查操作)

    设计功能的实现: ----没有业务层,直接由Servlet调用DAO,所以也没有事务操作,所以从DAO中直接获取connection对象 ----采用MVC设计模式 ----采用到的技术 .MVC设计 ...

  7. C#窗体中读取修改xml文件

    由于之前没有操作过xml文件,尤其是在窗体中操作xml,脑子一直转不动,而且很抵制去做这个功能,终于还是突破了自己通过查询资料完成了这个功能,在此记录一下自己的成果. 功能说明:程序中存在的xml文件 ...

  8. winform窗体(六)——DataGridView控件及通过此控件中实现增删改查

    DataGridView:显示数据表,通过此控件中可以实现连接数据库,实现数据的增删改查 一.后台数据绑定:    List<xxx> list = new List<xxx> ...

  9. Winform(DataGridView)控件及通过此控件中实现增删改查

    DataGridView:显示数据表,通过此控件中可以实现连接数据库,实现数据的增删改查 一.后台数据绑定:    List<xxx> list = new List<xxx> ...

随机推荐

  1. 想使用WM_CONCAT 函数进行多列转一行,但发现没有

    查看数据库版本: SELECT * FROM v$version; 1 Oracle Database 11g Enterprise Edition Release 11.1.0.7.0 - 64bi ...

  2. NOPI使用手册

    目录 1. 认识NPOI 2. 使用NPOI生成xls文件 2.1 创建基本内容 2.1.1 创建Workbook和Sheet 2.1.2 创建DocumentSummaryInformation和S ...

  3. 实现mysql的分组排名问题

    如下图所示的表结构,mysql中查出按照相同class的成员按照年龄排序. sql语句实现如下: SELECT id,name,age,rank FROM ( ,) AS rank,@pa:=ff.c ...

  4. SQL Server IO系统问题解决

    方法 1. 查询是不是真的要返回这么多的数据. 方法 2. 查询是不是系统的内存不足. 方法 3. 检查查询要访问的数据是不是不常用.如果这个数据不常用,它没有在内存中也就不奇怪了. 方法 4. 是不 ...

  5. SQL Server 统计信息的创建与更新

    前期准备: 普通表.临时表:它两会有统计信息. 表变量:           不会有统计信息. ---------------------------------------------------- ...

  6. eclipse中调出android sdk manager和android virtual device manager图标

    有时候在安装ADT插件后,eclipse菜单栏上不会显示android sdk manager和android virtual device manager两个图标, 这个时候,如果安装ADT插件的步 ...

  7. STL跨DLL使用

    今天在写一个函数,需要将map作为一个引用参数传入函数体内部进行赋值,结果编译通过,执行时总是崩溃,在网上找到了一些作者写的blog,详细解释了这种情况发生的原因,特转载在这里,便于自己今后查询. 原 ...

  8. Coursera-Neural Networks by Geoffrey Hinton

    feed-forward networks symmetrically-connection neural networks

  9. Recover a file even if it was not committed but it has to have been added when you use git reset head by mistake.

    git init echo hello >> test.txt git add test.txt Now the blob is created but it is referenced ...

  10. HDOJ1166 敌兵布阵

    赤裸裸的线段树,借个模板,改写一下即可. 代码: #include<iostream> #include<cstdio> #include<stdio.h> #in ...