概述
Linq也就是Language Integrated Query的缩写,即语言集成查询,是微软在.Net 3.5中提出的一项新技术。
Linq主要包含4个组件---Linq to Objects、Linq to XML、Linq to DataSet 和Linq to SQL。
- Linq to SQL 组件——可以查询基于关系数据的数据
- Linq to Dataset组件——可以查询DasaSet对象中的数据,并对数据进行增删改查的操作
- Linq to Objects组件——可以查询IEnumberable 或IEnumberable<T>集合
- Linq to XML 组件——可以查询和操作XML文件,比Xpath操作XML更加方便
一、使用Linq创建XML文件
1 public static class XMLFileHelper
2 {
3 /// <summary>
4 /// Create a xml file
5 /// </summary>
6 /// <param name="xmlPath"></param>
7 private static void CreateXmlFile(string xmlPath)
8 {
9 try
10 {
11 //定义一个XDocument结构
12 object[] content = new object[20];
13 content[0] = new XElement("User", new XAttribute("Id", "1"),
14 new XElement("Name", "Jack"),
15 new XElement("Password", "123456"),
16 new XElement("Description", "I am Jack")
17 );
18 content[1] = new XElement("User", new XAttribute("Id", "2"),
19 new XElement("Name", "Mary"),
20 new XElement("Password", "135678"),
21 new XElement("Description", "I am Mary")
22 );
23 content[2] = new XAttribute("Id", "root");
24
25 content[3] = new XElement("User", new XAttribute("Id", "3"),
26 new XElement("Name", "Tom"),
27 new XElement("Password", "654123"),
28 new XElement("Description", "I am Tom")
29 );
30
31 XDocument myXDoc = new XDocument(new XElement("Users", content));
32 myXDoc.Save(xmlPath);
33 }
34 catch (Exception ex)
35 {
36 Console.WriteLine(ex.ToString());
37 }
38 }
39 }
创建后的xml文件如下所示:
二、使用Linq读取Xml文件
1 public static void GetXmlNodeInformation(string xmlPath)
2 {
3 try
4 {
5 //定义并从xml文件中加载节点(根节点)
6 XElement rootNode = XElement.Load(xmlPath);
7 //查询语句: 获得根节点下name子节点(此时的子节点可以跨层次:孙节点、重孙节点......)
8 IEnumerable<XElement> targetNodes = from target in rootNode.Descendants("Name")
9 where target.Value.Contains("a")
10 select target;
11 foreach (XElement node in targetNodes)
12 {
13 Console.WriteLine("Name = {0}", node.Value);
14 }
15 Console.WriteLine();
16 IEnumerable<XElement> myTargetNodes = from myTarget in rootNode.Descendants("User")
17 where myTarget.HasElements
18 select myTarget;
19 foreach (XElement node in myTargetNodes)
20 {
21 Console.WriteLine("Name = {0}", node.Element("Name").Value);
22 Console.WriteLine("Password = {0}", node.Element("Password").Value);
23 Console.WriteLine("Description = {0}", node.Element("Description").Value);
24 Console.WriteLine();
25 }
26 }
27 catch (Exception ex)
28 {
29 Console.WriteLine(ex.ToString());
30 }
31 }
运行结果如下:
三、使用Linq修改Xml文件
1 public static void ModifyXmlNodeInformation(string xmlPath)
2 {
3 try
4 {
5 //定义并从xml文件中加载节点(根节点)
6 XElement rootNode = XElement.Load(xmlPath);
7 IEnumerable<XElement> targetNodes = from target in rootNode.Descendants("User")
8 where target.Element("Name").Value=="Mary"
9 select target;
10 //遍历所获得的目标节点(集合)
11 foreach (XElement node in targetNodes)
12 {
13 //将用户名为Mary的User节点修改为Emma
14 node.Element("Name").SetValue("Emma");
15 node.Element("Description").SetValue("I am Emma");
16 }
17 //保存对xml的更改操作
18 rootNode.Save(xmlPath);
19 }
20 catch (Exception ex)
21 {
22 Console.WriteLine(ex.ToString());
23 }
24 }
修改后的xml文件如下所示:
四、添加新节点
1 public static void AddXmlNodeInformation(string xmlPath)
2 {
3 try
4 {
5 //定义并从xml文件中加载节点(根节点)
6 XElement rootNode = XElement.Load(xmlPath);
7 //定义一个新节点
8 XElement newNode = new XElement("User", new XAttribute("Id", "4"),
9 new XElement("Name", "Rose"),
10 new XElement("Password", "333333"),
11 new XElement("Description", "I am Rose"));
12 //将此新节点添加到根节点下
13 rootNode.Add(newNode);
14 //保存对xml的更改操作
15 rootNode.Save(xmlPath);
16 }
17 catch (Exception ex)
18 {
19 Console.WriteLine(ex.ToString());
20 }
21 }
结果如下:
五、删除节点
1 public static void DeleteXmlNodeInformation(string xmlPath)
2 {
3 try
4 {
5 //定义并从xml文件中加载节点(根节点)
6 XElement rootNode = XElement.Load(xmlPath);
7 //查询语句: 获取ID属性值等于"999999"的所有User节点
8 IEnumerable<XElement> targetNodes = from target in rootNode.Descendants("User")
9 let id= Convert.ToInt32(target.Attribute("Id").Value)
10 where id >=3
11 select target;
12
13 targetNodes.Remove();
14 //保存对xml的更改操作
15 rootNode.Save(xmlPath);
16
17 }
18 catch (Exception ex)
19 {
20 Console.WriteLine(ex.ToString());
21 }
22 }
运行结果如下:
六、实际应用---判断桌面上是否存在指定文件以及具体路径
1 private static string FileQuery(string targetFileName)
2 {
3 string myDeskTopDir = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
4 string []fileNames = Directory.GetFiles(myDeskTopDir, "*.*", SearchOption.AllDirectories);
5 List<FileInfo> files = new List<FileInfo>();
6 foreach(var fileName in fileNames)
7 {
8 files.Add(new FileInfo(fileName));
9 }
10 var results = from file in files
11 where file.Name == targetFileName
12 select file;
13 StringBuilder queryResult = new StringBuilder();
14 foreach(var result in results)
15 {
16 queryResult.AppendLine("Query Result:" + result.FullName);
17 }
18 return queryResult.ToString();
19 }
C#基础知识---Linq操作XML文件的更多相关文章
-
应用Xml.Linq读xml文件
c#提供了System.Xml.Linq操作xml文件,非常方便,本文主要介绍如何应用System.Xml.Linq读取xml文件. xml文本 <?xml version="1.0& ...
-
JAVA中通过Jaxp操作XML文件基础
Java中有多种方式操作XML文件,目前讲一讲以SUN公司提供的DocumentBuilderFactory工厂类对象操作XML. 使用XML基本操作就是需要CRUD(增删改查),那么首先通过一个查询 ...
-
Asp.Net 操作XML文件的增删改查 利用GridView
不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...
-
C#操作xml文件:使用XmlDocument 实现读取和写入
XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影.Xml是Internet环境中跨平台的,依赖于内 ...
-
Java操作XML文件 dom4j 篇
在项目中,我们很多都用到了xml文件,无论是参数配置还是与其它系统的数据交互.今天就来讲一下Java 中使用dom4j来操作XML文件. 我们需要引入的包: //文件包 import java.io. ...
-
PHP操作XML文件学习笔记
原文:PHP操作XML文件学习笔记 XML文件属于标签语言,可以通过自定义标签存储数据,其主要作用也是作为存储数据. 对于XML的操作包括遍历,生成,修改,删除等其他类似的操作.PHP对于XML的操作 ...
-
Qt之QDomDocument操作xml文件-模拟ini文件存储
一.背景 不得不说Qt是一个很强大的类库,不管是做项目还是做产品,Qt自身封装的东西就已经非常全面了,我们今天的这篇文章就是模拟了Qt读写ini文件的一个操作,当然是由于一些外力原因,我们决定自己来完 ...
-
Linux基础知识第三讲,拷贝文件跟移动文件命令
目录 Linux基础知识第三讲,拷贝文件跟移动文件命令 一丶常用命令 1.tree命令常用选项 2.cp复制文件命令 3.mv 命令的使用 Linux基础知识第三讲,拷贝文件跟移动文件命令 一丶常用命 ...
-
WebAPI调用笔记 ASP.NET CORE 学习之自定义异常处理 MySQL数据库查询优化建议 .NET操作XML文件之泛型集合的序列化与反序列化 Asp.Net Core 轻松学-多线程之Task快速上手 Asp.Net Core 轻松学-多线程之Task(补充)
WebAPI调用笔记 前言 即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录. 接口描述 首先说明一下,基于 ...
随机推荐
-
SQLServer 数据库镜像+复制方案
目标: 主机做了Mirror和Replication,当主机出现问题时,Replication和Mirror实现自动的故障转移(Mirror 和Replication都切换到备机,而当主机 重新启动后 ...
-
Third Day(上班第四天):Android开发环境配置问题相关
换公司新电脑了,重新安装Android开发环境,并配置,具体流程如下:1.百度JDK,访问Oracle官网:http://www.oracle.com/technetwork/java/javase/ ...
-
rem介绍
手机端开发,一般以320px宽为最低标题.市场上的手机,大多数是360px宽. 20px=1rem是最容易换算的,基本上可以口算,除以2并缩小十倍.1px/20=0.05rem.两位小数就可以除尽了. ...
-
UVa 10055 - Hashmat the Brave Warrior
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=94&page=s ...
-
STL模板_容器概念
一.STL(Standard Template Library,标准模板库)概述1.容器:基于泛型的数据结构.2.算法:基于泛型的常用算法.3.迭代器:以泛型的方式访问容器中的元素,是泛型的算法可以应 ...
- crawler_大型舆情架构图
-
Robotframe work学习之初(二)
一.F5帮助 Robot Framework 并没有像其它框架一样提供一份完整的 API 文档,所以,我们没办法通过官方 API文档进行习.RIDE 提供了 F5 快捷键来打开帮助文档. search ...
-
mysql安转过程中出现的问题! Fatal error: Can&#39;t open and lock privilege tables: Table &#39;mysql.user&#39; doesn&#39;t exis
net start mysql启动失败,报错信息如上,因缺少mysql这个库 所以跳过 在my.ini中添加 --skip-grant-tables 再启动mysql 然后进入mysql 倒入一个从其 ...
-
spring data jpa 分页查询
https://www.cnblogs.com/hdwang/p/7843405.html spring data jpa 分页查询 法一(本地sql查询,注意表名啥的都用数据库中的名称,适用于特 ...
-
2017.11.10 重读C++ Primer
第二章 变量和变量类型 1. C++ 算数类型 bool 布尔 最小尺寸未定义 char 字符 8位 wchar_t ...