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 ...
随机推荐
- 【C】——itoa 函数的实现
itoa函数的实现,函数实现功能:输入一个 int 型的数据然后修改成 十六进制的字符串. 例如: 输入 100 输出 0x64 主函数: int main(void){ ]; my_atoi(v ...
- 【C】——APUE小程序之递归遍历目录
递归降序遍历目录层次结构,并按文件类型计数. 先介绍相关的函数: #include<dirent.h> DIR *opendir(const char *pathname); //打开目录 ...
- jquery.nestable.min.js可拖动标签
主容器为一个叫div的classname为dd的东西. 只要对这个主容器进行捕获加上一个方法 nestable就可以了. 可以给的属性为 serialize 直接以字符串的形式给入,意思就是按 ...
- poj 1723 中位数
最近在看一些中位数的东西,然后顺便也看了些题目.poj 1723不仅要求到水平位置的最短距离和,还要求水平都相邻的排成一排的最短距离和,即士兵都站成一列. 到y轴的距离好办,按y轴坐标排序,求中位数, ...
- Ubuntu中基于QT的系统网线连接状态的实时监视
1.必要准备 需包: #include <QNetworkInterface> 2.实现获取当前的网线连接状态 以下是自己在网络上搜到的一个解决方法,且没有加入iface.flags(). ...
- PinnedListView分析一
分享一个Android控件,PinnedHeaderListView , 大致是像图钉一样,能够固定显示一个头部在ListView的顶部,类似于Android原版通讯录中联系人按照字母分组排列, 这个 ...
- Linux之查看切换Shell
1.查看存在的shell cat /etc/shells 2.查看使用的shell echo $SHELL 3.切换shell 切换bash chsh -s /bin/bash 切换zsh chsh ...
- CSS的块级元素和内联元素,以及float
说明:之前有一点搞错了,就是float其实是浮动起来,其它元素会位于它的底层. 最近在系统地学习HTML5,感觉补上了好多缺失的知识. 例如: 锚点定位其实可以通过 id 来实现: CSS 使用 !i ...
- matlab中常用的函数
find()函数: 功能:用于返回矩阵中想要的元素的索引值: 用法: index = find(X), 当X为一个矩阵时,返回的index是一个列向量,表示矩阵X中非零值的索引值,这个索引值吧,是按把 ...
- Java如何显示一年的周数?
在Java中,如何查找一年中或一个月中的第几个星期? 以下示例显示年份和月份的第几周. package com.yiibai; import java.util.*; public class Dis ...