linq to xml 增删查改
一、XML基本概述
XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影。Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具。XML是一种简单的数据存储语言,使用一系列简单的标记描述数据,而这些标记可以用方便的方式建立,虽然XML占用的空间比二进制数据要占用更多的空间,但XML极其简单易于掌握和使用。微软也提供了一系列类库来倒帮助我们在应用程序中存储XML文件。
“在程序中访问进而操作XML文件一般有两种模型,分别是使用DOM(文档对象模型)和流模型,使用DOM的好处在于它允许编辑和更新XML文档,可以随机访问文档中的数据,可以使用XPath查询,但是,DOM的缺点在于它需要一次性的加载整个文档到内存中,对于大型的文档,这会造成资源问题。流模型很好的解决了这个问题,因为它对XML文件的访问采用的是流的概念,也就是说,任何时候在内存中只有当前节点,但它也有它的不足,它是只读的,仅向前的,不能在文档中执行向后导航操作。
三种常用的读取XML文件的方法。分别是
①使用XmlDocument
②使用XmlTextReader
③使用Linq to Xml
本文主要讨论使用Linq to Xml的方法实现对XML文档的创建、增加、删除、修改、查询的操作。
二、创建XML文档
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Xml.Linq;
- namespace CreateXML
- {
- class Program
- {
- static void Main(string[] args)
- {
- //实例化XDocument对象
- XDocument xdoc = new XDocument();
- //创建根节点
- XElement root = new XElement("school");
- //创建子节点
- XElement cls = new XElement("class");
- cls.SetAttributeValue("number", "0302"); //添加子节点的属性,如3年级2班
- //创建子节点class的子节点学生stu1
- XElement stu1 = new XElement("student");
- stu1.SetAttributeValue("id", "001"); //添加子节点stu1的属性,如学号001
- stu1.SetElementValue("name", "张三"); //添加子节点stu1的数据,如姓名张三
- stu1.SetElementValue("gender", "男"); //添加子节点stu1的数据,如性别男
- stu1.SetElementValue("age", "19"); //添加子节点stu1的数据,如年龄19
- //创建子节点class的子节点学生stu2
- XElement stu2 = new XElement("student");
- stu2.SetAttributeValue("id", "002"); //添加子节点stu2的属性,如学号002
- stu2.SetElementValue("name", "李晓梅"); //添加子节点stu2的数据,如姓名李晓梅
- stu2.SetElementValue("gender", "女"); //添加子节点stu2的数据,如性别女
- stu2.SetElementValue("age", "18"); //添加子节点stu2的数据,如年龄18
- cls.Add(stu1); //添加student到class
- cls.Add(stu2); //添加student到class
- root.Add(cls); //添加子节点class到根节点school
- xdoc.Add(root); //添加根节点到XDoucment对象
- xdoc.Save("1.xml"); //使用XML的保存会自动在xml文件开始添加:<?xml version="1.0" encoding="utf-8"?>
- Console.WriteLine("创建XML文件成功!");
- Console.ReadKey();
- }
- }
- }
生成的xml文档如下:
- <?xml version="1.0" encoding="utf-8"?>
- <school>
- <class number="0302">
- <student id="001">
- <name>张三</name>
- <gender>男</gender>
- <age>19</age>
- </student>
- <student id="002">
- <name>李晓梅</name>
- <gender>女</gender>
- <age>18</age>
- </student>
- </class>
- </school>
三、读取XML文档
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Xml.Linq;
- namespace ReadXML
- {
- class Program
- {
- static void Main(string[] args)
- {
- string path = "1.xml";
- XDocument xdoc = XDocument.Load(path); //加载xml文件
- XElement rootSchool = xdoc.Root; //获取根元素
- //Console.WriteLine(rootSchool.Name); //根元素的名字
- IEnumerable<XElement> xeles = rootSchool.Elements(); //获取根元素下所有的直接子元素
- foreach (XElement xeleClass in xeles)
- {
- foreach (XElement xeleStudent in xeleClass.Elements())
- {
- Console.WriteLine(xeleStudent.Name); //获取节点名
- Console.WriteLine(xeleStudent.Attribute("id").Value); //获取属性值
- Console.WriteLine(xeleStudent.Element("name").Value); //下面3行是获取数据
- Console.WriteLine(xeleStudent.Element("gender").Value);
- Console.WriteLine(xeleStudent.Element("age").Value);
- }
- }
- Console.ReadKey();
- }
- }
- }
运行结果如下图:
三、增加XML文档内容
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Xml.Linq;
- namespace AddXML
- {
- class Program
- {
- static void Main(string[] args)
- {
- string path = "1.xml";
- XDocument xdoc = XDocument.Load(path);
- XElement xeleRoot = xdoc.Root;
- //在已存在的节点上添加属性和数据
- XElement xeleClass = xeleRoot.Element("class");
- XElement xeleStu3 = new XElement("student");
- xeleStu3.SetAttributeValue("id", "005");
- xeleStu3.SetElementValue("name", "王五");
- xeleStu3.SetElementValue("gender", "男");
- xeleStu3.SetElementValue("age", "40");
- xeleClass.Add(xeleStu3);
- //在根节点下添加新的直接子节点及次级节点的属性和数据
- //XElement xeleClass = new XElement("class");
- //xeleClass.SetAttributeValue("number", "0501");
- //XElement xeleStu1 = new XElement("student");
- //xeleStu1.SetAttributeValue("id", "003");
- //xeleStu1.SetElementValue("name","刘芳");
- //xeleStu1.SetElementValue("gender","女");
- //xeleStu1.SetElementValue("age","26");
- //XElement xeleStu2 = new XElement("student");
- //xeleStu2.SetAttributeValue("id", "004");
- //xeleStu2.SetElementValue("name", "王亮");
- //xeleStu2.SetElementValue("gender", "男");
- //xeleStu2.SetElementValue("age", "36");
- //xeleClass.Add(xeleStu1);
- //xeleClass.Add(xeleStu2);
- //xeleRoot.Add(xeleClass);
- xdoc.Save("1.xml");
- Console.WriteLine("添加xml成功");
- Console.ReadKey();
- }
- }
- }
在已存在的节点上添加属性和数据,xml文件如下:
- <?xml version="1.0" encoding="utf-8"?>
- <school>
- <class number="0302">
- <student id="001">
- <name>张三</name>
- <gender>男</gender>
- <age>19</age>
- </student>
- <student id="002">
- <name>李晓梅</name>
- <gender>女</gender>
- <age>18</age>
- </student>
- <student id="005">
- <name>王五</name>
- <gender>男</gender>
- <age>40</age>
- </student>
- </class>
- </school>
上面被消隐的代码放开之后,在根节点下添加新的直接子节点及次级节点的属性和数据,xml文件如下:
- <?xml version="1.0" encoding="utf-8"?>
- <school>
- <class number="0302">
- <student id="001">
- <name>张三</name>
- <gender>男</gender>
- <age>19</age>
- </student>
- <student id="002">
- <name>李晓梅</name>
- <gender>女</gender>
- <age>18</age>
- </student>
- </class>
- <class number="0501">
- <student id="003">
- <name>刘芳</name>
- <gender>女</gender>
- <age>26</age>
- </student>
- <student id="004">
- <name>王亮</name>
- <gender>男</gender>
- <age>36</age>
- </student>
- </class>
- </school>
四、删除XML文档内容
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Xml.Linq;
- namespace DeleteXML
- {
- class Program
- {
- static void Main(string[] args)
- {
- XDocument xdoc = XDocument.Load("1.xml");
- XElement xeleRoot = xdoc.Root;
- //删除根节点的直接子节点
- XElement xeleClass = xeleRoot.Elements("class").Where(x => x.Attribute("number").Value == "0302").Single(); //拉姆达表达式
- xeleClass.Remove();
- //删除根节点的直接子节点的下一级节点
- //XElement xeleClass = xeleRoot.Elements("class").Where(x => x.Attribute("number").Value == "0302").Single(); //获取班级号为0302的直接子节点
- //XElement xeleStudent = xeleClass.Elements("student").Where(x => x.Attribute("id").Value == "001").Single(); //获取学号为001的直接子节点的下一级节点
- //xeleStudent.Remove();
- xdoc.Save("1.xml");
- Console.WriteLine("删除节点成功!");
- Console.ReadKey();
- }
- }
- }
删除根节点的直接子节点,xml文件如下:
- <?xml version="1.0" encoding="utf-8"?>
- <school>
- <class number="0501">
- <student id="003">
- <name>刘芳</name>
- <gender>女</gender>
- <age>26</age>
- </student>
- <student id="004">
- <name>王亮</name>
- <gender>男</gender>
- <age>36</age>
- </student>
- </class>
- </school>
删除根节点的直接子节点的下一级节点,xml文件如下:
- <?xml version="1.0" encoding="utf-8"?>
- <school>
- <class number="0302">
- <student id="002">
- <name>李晓梅</name>
- <gender>女</gender>
- <age>18</age>
- </student>
- </class>
- <class number="0501">
- <student id="003">
- <name>刘芳</name>
- <gender>女</gender>
- <age>26</age>
- </student>
- <student id="004">
- <name>王亮</name>
- <gender>男</gender>
- <age>36</age>
- </student>
- </class>
- </school>
五、修改XML文档内容
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Xml.Linq;
- namespace UpdateXML
- {
- class Program
- {
- static void Main(string[] args)
- {
- XDocument xdoc = XDocument.Load("1.xml");
- XElement xeleRoot = xdoc.Root;
- XElement xeleClass = xeleRoot.Elements("class").Where(x => x.Attribute("number").Value == "0302").Single(); //获取班级号为0302的直接子节点
- XElement xeleStudent = xeleClass.Elements("student").Where(x => x.Attribute("id").Value == "001").Single(); //获取学号为001的直接子节点的下一级节点
- xeleStudent.SetAttributeValue("id", "008");
- xeleStudent.SetElementValue("name","邦德");
- xeleStudent.SetElementValue("gender","爷们");
- xeleStudent.SetElementValue("age","39");
- xdoc.Save("1.xml");
- Console.WriteLine("修改成功!");
- Console.ReadKey();
- }
- }
- }
执行后xml文件如下:
- <?xml version="1.0" encoding="utf-8"?>
- <school>
- <class number="0302">
- <student id="008">
- <name>邦德</name>
- <gender>爷们</gender>
- <age>39</age>
- </student>
- <student id="002">
- <name>李晓梅</name>
- <gender>女</gender>
- <age>18</age>
- </student>
- </class>
- <class number="0501">
- <student id="003">
- <name>刘芳</name>
- <gender>女</gender>
- <age>26</age>
- </student>
- <student id="004">
- <name>王亮</name>
- <gender>男</gender>
- <age>36</age>
- </student>
- </class>
- </school>
linq to xml 增删查改的更多相关文章
- XML 增删查改
<?xml version="1.0" encoding="utf-8"?> <users> <person name=" ...
- C# xml增删查改
C# XML XmlDocument 添加命名空间: using System.Xml; 定义公共对象: XmlDocument xmldoc ; XmlNode xmlnode ; XmlEleme ...
- c#中xml增删查改
/// <summary> /// xml转list /// </summary> /// <typeparam name="T">目标对象&l ...
- java:Hibernate框架1(环境搭建,Hibernate.cfg.xml中属性含义,Hibernate常用API对象,HibernteUitl,对象生命周期图,数据对象的三种状态,增删查改)
1.环境搭建: 三个准备+7个步骤 准备1:新建项目并添加hibernate依赖的jar文件 准备2:在classpath下(src目录下)新建hibernate的配置文件:hibernate.cf ...
- 4.在MVC中使用仓储模式进行增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-using-the-repository-pattern-in-mvc/ 系列目录: ...
- Nhibernate入门篇连接Sqlserver的增删查改
第一步:创建数据库 create table Emp( EmpId int primary key identity, EmpName ), EmpDate date ) 第二步:去官网下载:http ...
- 6.在MVC中使用泛型仓储模式和依赖注入实现增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...
- 3.EF 6.0 Code-First实现增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-entity-framework-5-0-code- ...
- 5.在MVC中使用泛型仓储模式和工作单元来进行增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...
随机推荐
- 中国移动DNS IP地址大全(32个省)
中国移动DNS IP地址,包括广东移动DNS,上海移动DNS,北京移动DNS,陕西移动DNS,江苏移动,山东移动DNS等共全国32个移动省份的DNS IP地址. DNS 用户数 国家 省份 地区 运营 ...
- hadoop2.7节点的动态增加与删除
参考这里: https://blog.csdn.net/Mark_LQ/article/details/53393081
- 非常有用的15个Linux 服务器监控命令
如果你想知道你的服务器正在做干什么,你就需要了解一些基本的命令,一旦你精通了这些命令,那你就是一个 专业的 Linux 系统管理员. 有些 Linux 发行版会提供 GUI 程序来进行系统的监控,例如 ...
- hbase源码系列(十三)缓存机制MemStore与Block Cache
这一章讲hbase的缓存机制,这里面涉及的内容也是比较多,呵呵,我理解中的缓存是保存在内存中的特定的便于检索的数据结构就是缓存. 之前在讲put的时候,put是被添加到Store里面,这个Store是 ...
- Android Studio生成keystore签名文件步骤讲解
Android App打包时要用到签名文件,Android Studio生成签名文件步骤如下: Build---Generate Signed Apk...如图: 如果你的project中有2个或者2 ...
- mysql 5.7.10 启动多实例笔记
1. 复制配置文件 cp /etc/my.cnf /etc/my3308.cnf 2. 修改配置文件 3. 创建目录, 并赋予权限 4. 初始化数据库 ---> 有报错 2018-01-03T0 ...
- (笔记)Mysql命令desc:获取数据表结构
desc命令用于获取数据表结构. desc命令格式: desc 表名;同样 show columns from 表名;也能获取数据表结构. 举例如下:mysql> desc MyCl ...
- elasticsearch系列二:索引详解(快速入门、索引管理、映射详解、索引别名)
一.快速入门 1. 查看集群的健康状况 http://localhost:9200/_cat http://localhost:9200/_cat/health?v 说明:v是用来要求在结果中返回表头 ...
- Spring JDBC多批次操作
以下示例将演示如何使用spring jdbc在单个调用中进行多批次更新. 我们将在批量大小为1的多批次操作中更新student表中的记录. student表的结果如下 - CREATE TABLE s ...
- 目标检测之dpm---hog的最优升级版
http://blog.csdn.net/ttransposition/article/details/12966521 http://blog.csdn.net/carson2005/article ...