概述

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文件的更多相关文章

  1. 应用Xml.Linq读xml文件

    c#提供了System.Xml.Linq操作xml文件,非常方便,本文主要介绍如何应用System.Xml.Linq读取xml文件. xml文本 <?xml version="1.0& ...

  2. JAVA中通过Jaxp操作XML文件基础

    Java中有多种方式操作XML文件,目前讲一讲以SUN公司提供的DocumentBuilderFactory工厂类对象操作XML. 使用XML基本操作就是需要CRUD(增删改查),那么首先通过一个查询 ...

  3. Asp.Net 操作XML文件的增删改查 利用GridView

    不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...

  4. C#操作xml文件:使用XmlDocument 实现读取和写入

    XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影.Xml是Internet环境中跨平台的,依赖于内 ...

  5. Java操作XML文件 dom4j 篇

    在项目中,我们很多都用到了xml文件,无论是参数配置还是与其它系统的数据交互.今天就来讲一下Java 中使用dom4j来操作XML文件. 我们需要引入的包: //文件包 import java.io. ...

  6. PHP操作XML文件学习笔记

    原文:PHP操作XML文件学习笔记 XML文件属于标签语言,可以通过自定义标签存储数据,其主要作用也是作为存储数据. 对于XML的操作包括遍历,生成,修改,删除等其他类似的操作.PHP对于XML的操作 ...

  7. Qt之QDomDocument操作xml文件-模拟ini文件存储

    一.背景 不得不说Qt是一个很强大的类库,不管是做项目还是做产品,Qt自身封装的东西就已经非常全面了,我们今天的这篇文章就是模拟了Qt读写ini文件的一个操作,当然是由于一些外力原因,我们决定自己来完 ...

  8. Linux基础知识第三讲,拷贝文件跟移动文件命令

    目录 Linux基础知识第三讲,拷贝文件跟移动文件命令 一丶常用命令 1.tree命令常用选项 2.cp复制文件命令 3.mv 命令的使用 Linux基础知识第三讲,拷贝文件跟移动文件命令 一丶常用命 ...

  9. WebAPI调用笔记 ASP.NET CORE 学习之自定义异常处理 MySQL数据库查询优化建议 .NET操作XML文件之泛型集合的序列化与反序列化 Asp.Net Core 轻松学-多线程之Task快速上手 Asp.Net Core 轻松学-多线程之Task(补充)

    WebAPI调用笔记   前言 即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录. 接口描述 首先说明一下,基于 ...

随机推荐

  1. UI自动化学习笔记- PO模型介绍和使用

    一.PO模型 1.PO介绍:page(页面) object(对象) 在自动化中,Selenium 自动化测试中有一个名字经常被提及 PageObject (思想与面向对象的特征相同),通常PO 模型可 ...

  2. 微信小程序云开发-云存储-上传、下载、打开文件文件(word/excel/ppt/pdf)一步到位

    一.wxml文件 <!-- 上传.下载.打开文件一步执行 --> <view class="handle"> <button bindtap=&quo ...

  3. POJ3264线段树求最值

    刚开始还觉得有点怪怪的.因为想着如果每个树只是单纯地记录它所在的区间的话会不会有不在区间内的数据给更新了,但是我好像是傻掉了因为如果有这种情况出现的话在父亲节点就会分成l,mid和mid+1,r两个区 ...

  4. js中的 true 与 false

    可判断为 false 的情况: 0,-0,NaN,undedined,"",false,null,缺省的值 可判断为 true 的情况: 除false的其他情况均可,包括负数.&q ...

  5. npm 安装、卸载模块

    npm安装模块 [npm install xxx]利用 npm 安装xxx模块到当前命令行所在目录:[npm install -g xxx]利用npm安装全局模块xxx:本地安装时将模块写入packa ...

  6. odoo里的开发案例

    1.模块命名[驼峰命名方法] res开头的是:resources   常见模型:res.users,   res.company,    res.partner,   res.config.setti ...

  7. Qt Creator 入门

    Qt 的入门我觉得可以直接从窗口开始,而不是什么"Hello World!".因为Qt 是一个基于图形界面的编程软件,图形界面编程是其核心所在.很久以前,那时候还是Shell编程, ...

  8. 文件上传靶机DVWA和upload-labs

    DVWA靶机 LOW <?php phpinfo() ?> 上传文件 Medium级别 修改Content-Type: application/octet-stream的值为jpg的格式为 ...

  9. anyRTC 6月SDK更新迭代

    anyRTC 6月更新迭代,macOS新增屏幕 ID 进行屏幕共享功能,让共享更高效简单:此外解决了视频的宽高不是16:9导致共享内容缺失的问题,同时对音视频模块,推流组件等多项功能进行了优化改进. ...

  10. QGIS打印布局中绘制多个子图

    QGIS如何绘制多图 数据准备 这是一份英国大曼彻斯特地区的数据,里面包含了教育.收入.人口密度.绿地比例.城市比例等数据,我们准备把这些数据在地图上呈现出来,为此,我们需要做在地图中绘制6幅子图,这 ...