XML——对XML文档的创建与增删改查

原文:XML——对XML文档的创建与增删改查

一、创建的第一种方式 

            //1、创建一个XML文档
            XmlDocument doc = new XmlDocument();
            //2、创建第一行描述信息
            XmlDeclaration dec = doc.CreateXmlDeclaration("1.0", "utf-8", null);
            //3、将创建的第一行描述信息添加到文档中
            doc.AppendChild(dec);
            //4、给文档添加根节点
            XmlElement Books =  doc.CreateElement("Books");
            doc.AppendChild(Books);
            XmlElement Book = doc.CreateElement("Book");
            Books.AppendChild(Book);
            XmlElement name = doc.CreateElement("name");
            name.InnerText = "水浒传";
            Book.AppendChild(name);
            XmlElement author = doc.CreateElement("author");
            author.InnerText = "匿名";
            author.SetAttribute("name", "wjl");
            author.SetAttribute("count", "30");
            Book.AppendChild(author);
            doc.Save("Book.xml");
            Console.WriteLine("保存成功!");
            Console.ReadKey();

创建结果如下:

二、创建的第二种方式

   class Program          {
              static void Main(string[] args)              {
                  List<Student> list = new List<Student>();                  list.Add(new Student(1, "wjl1", 22, "男"));                  list.Add(new Student(2, "wjl2", 21, "男"));                  list.Add(new Student(3, "wjl3", 22, "男"));                  list.Add(new Student(4, "wjl4", 24, "男"));                 XmlDocument xmldoc = new XmlDocument();                 XmlDeclaration xmldec = xmldoc.CreateXmlDeclaration("1.0", "utf-8", null);                 xmldoc.AppendChild(xmldec);                 XmlElement person = xmldoc.CreateElement("Person");                xmldoc.AppendChild(person);                 for (int i = 0; i < list.Count; i++)                 {                     XmlElement stu = xmldoc.CreateElement("student");                     stu.SetAttribute("ID", list[i].Id.ToString());                     person.AppendChild(stu);                     XmlElement name = xmldoc.CreateElement("name");                     XmlElement age = xmldoc.CreateElement("age");                     name.InnerText = list[i].Name;                     age.InnerText = list[i].Age.ToString();                     stu.AppendChild(name);                     stu.AppendChild(age);                }                 xmldoc.Save("Student.xml");                Console.WriteLine("Student.xml");                Console.ReadKey();             }        }         class Student         {            int id;            string name;            int age;            string sex;            public Student(int id, string name, int age, string sex)             {                 this.id = id;                 this.name = name;                 this.age = age;                 this.sex = sex;           }            public Student()            {            }         }

 创建结果如下:

三、对XML文件的添加

            XmlDocument doc = new XmlDocument();
            //首先判断文件是否存在,如果存在则追加否则在创建一个
            if (File.Exists("Student.xml"))
            {
                //加载
                doc.Load("Student.xml");
                //获取根节点,给根节点添加子节点
                XmlElement person = doc.DocumentElement;
                XmlElement student = doc.CreateElement("student");
                student.SetAttribute("ID", "1");
                person.AppendChild(student);
                XmlElement name = doc.CreateElement("name");
                XmlElement age = doc.CreateElement("age");
                name.InnerText = "zjs";
                age.InnerText = "41";
                student.AppendChild(name);
                student.AppendChild(age);
            }
            else {
            }
            doc.Save("Student.xml");
            Console.WriteLine("Student.xml 保存成功");

四、对XML文档的查询、修改、删除

方法1:

文档结构为:

if (File.Exists("order.xml"))
            {
                doc.Load("order.xml");
                // 获取根节点
                XmlElement orderElement  = doc.DocumentElement;
                XmlNodeList orderChildr  = orderElement.ChildNodes;
                foreach (XmlNode item in orderChildr)
                {
                    Console.WriteLine("节点名称:"+ item.Name + "节点的 InnerText :" + item.InnerText);
                }
                XmlElement orderitem = orderElement["Items"];
                XmlNodeList itemlist = orderitem.ChildNodes;
                foreach (XmlNode item in itemlist)
                {
                    Console.WriteLine(item.Attributes["Name"].Value + " " + item.Attributes["Count"].Value);
                }
  }
            else
            {
                Console.WriteLine("文件不存在!");
            }
            Console.ReadKey();
           // doc.Save("Student.xml");
            Console.WriteLine("Student.xml 保存成功");
  

方法2:

            #region 使用XPath的方式来读取XML文件
            // 获取文档对象
            XmlDocument doc = new XmlDocument();
            doc.Load("order.xml");
            //获取根节点
            XmlElement order = doc.DocumentElement;
            // 获取单个节点
            //XmlNode xn = order.SelectSingleNode(@"/Order/CustomerName");
            XmlNode xn = order.SelectSingleNode(@"/Order/Items/OrderItem[@Name=‘码表‘]");
            xn.Attributes["Count"].Value = "20"; // 修改
            doc.Save("Order.xml");
            Console.WriteLine(xn.Attributes["Count"].Value);
            Console.ReadKey();
            #endregion

删除元素指定的特性:

            xn.Attributes.RemoveNamedItem("Count");  //删除元素指定的特性

删除子节点:

            XmlNode xn = order.SelectSingleNode(@"/Order/Items");
            XmlNode xnchild  = order.SelectSingleNode(@"/Order/Items/OrderItem[@Name = ‘雨衣‘]");
            xn.RemoveChild(xnchild); //删除指定的子节点

删除当前所有子节点:

            xn.RemoveAll(); //删除当前节点的所有子节点   

删除当前节点的所有特性:

            xnchild.Attributes.RemoveAll(); 

原文地址:https://www.cnblogs.com/lonelyxmas/p/8915789.html

时间: 2024-10-12 10:34:43

XML——对XML文档的创建与增删改查的相关文章

使用DOM进行xml文档的crud(增删改查)操作&amp;lt;操作详解&amp;gt;

很多朋友对DOM有感冒,这里我花了一些时间写了一个小小的教程,这个能看懂,会操作了,我相信基于DOM的其它API(如JDOM,DOM4J等)一般不会有什么问题. 后附java代码,也可以下载(可点击这里入下载)导入到Eclipse或MyEclipse. Node和Element的关系 Element是Node的子接口,所以Element的方法要比Node方法要多,这样的话使用起来比较方便,一般情况我们都把节点转换成元素(或者叫标签,即Element); Element是Node的子类型: 比如我

使用DOM进行xml文档的crud(增删改查)操作&lt;操作详解&gt;

很多朋友对DOM有感冒,这里我花了一些时间写了一个小小的教程,这个能看懂,会操作了,我相信基于DOM的其它API(如JDOM,DOM4J等)一般不会有什么问题. 后附java代码,也可以下载(可点击这里入下载)导入到Eclipse或MyEclipse. Node和Element的关系 Element是Node的子接口,所以Element的方法要比Node方法要多,这样的话使用起来比较方便,一般情况我们都把节点转换成元素(或者叫标签,即Element); Element是Node的子类型: 比如我

Android(java)学习笔记245:ContentProvider之银行数据库创建和增删改查的实现

1.Android的四大组件: (1)Activity  用户交互的UI界面 (2)Service  后台运行的服务 (3)BroadcastReceiver 广播接收者 (4)ContentProvider  内容提供者 2. ContentProvider  内容提供者 用途:把应用程序私有的数据暴露给别的应用程序. 3.下面通过一个银行数据库创建和增删改查的实现案例说明ContentProvider的使用: (1)首先我们这里要用到数据库,首先我们必须先扩展一个抽象类SQLiteOpenH

【andorid基础篇】数据库的创建以及增删改查

I,安卓下的数据库 安卓下使用的数据库是SQLite,安卓为我们提供的API是SQLiteOpenHelper. 1,创建一个数据库 1)写一类去继承抽象类SQLiteOpenHelper,我们需要复写相关的方法: 1 public WcxSQLite(Context context, String name, CursorFactory factory,int version) { super(context, name, factory, version); 3 } 4 5 public v

数据库的创建和增删改查,外键和主键的创建

[关键字 ]paimary key [代表主键],not null[ 非空 ]foreign key[ 代表外键] (zhu) references[引用] zhu ( code)[ 建立外键关系 ]auto_increment[自动递增]注释语法:用#注释. 创建表create table test(  创建列:  code varchar[字符串]( 写长度 ),   name varchar( 20 )) 注意:1.每条语句后加分号:      2.最后一列不需要加逗号:      3.

数据库 基础知识创建及增删改查

1.查找数据库的主文件和日志文件所在位置: 右击数据库,点击属性,会出现下图: 可以看出,此数据库拥有一个主文件(mdf)和一个日志文件(ldf) 2.新建数据库: 右击数据库,新建数据库,输入数据库的名称 3.用语句新建数据库: 点击新建查询,在窗口内输入语句并点击执行 4.使用数据库并创建一个表,表中添加列名 5.在表中添加数据,并查询此表.(按照列名来添加,用逗号隔开) 6.各种增删改查的语句的使用示例

yii2-basic后台管理功能开发之二:创建CRUD增删改查

昨天实现了后台模板的嵌套,今天我们可以试着创建CRUD模型啦 刚开始的应该都是“套用”,不再打算细说,只把关键的地方指出来. CRUD即数据库增删改查操作.可以理解为yii2为我们做了一个组件,来实现基本的增删改查视图和操作. 1.创建数据库表 2.用gii生成model模型 3.用gii生成CRUD 需要注意的是CRUD生成的控制器的namespace,要和当前所在目录保持一致.否组路由会报错,找不到该页面等信息.

数据库与表的创建及增删改查

TSQL语句: [“.sql”结尾的文件是:保存用户对数据库和表操作的过程代码.注意:随时 ctrl+s 保存一下 字段名就是列名!] 一.数据库 1.创建数据库: create database [数据库名称],选中该行语句,点击“执行”或者选中按 F5,消息返回“命令已成功完成”,新数据库就创建完成啦! 如果你在“对象资源管理器”中找不到新建的数据库,那就右击“数据库”,点击“刷新”,就可以看到了 2.删除数据库: drop database [要删除的数据库],选中该行语句,点击“执行”,

Android SQLite服务--创建、增删改查

<pre name="code" class="java">import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.util.Log; /** * 默认就在数据库里创建4张表 * * */ public class DBOpen