这节将学习如何用 linq查询xml

一、我们先看看在xml中我们怎么操作

 public void xmlWayToQueryXmlFile()
{
XmlDocument xmldoc = new XmlDocument();
xmldoc.Load("../../xmlFile.xml"); XmlNode root = xmldoc.DocumentElement;
XmlNode node = root.SelectSingleNode("custom[id='100']");
Console.Write(node.InnerText);
}

 这是在using system.xml条件下查询xml中id=100的node下所有的innerText

关于在xml中查询方法,这里讲的比较详细http://www.cnblogs.com/fjsnail/archive/2012/10/20/2732127.html

二、我们看看用linq又怎么操作

函数一: Elements()返回XML文档或片段中的所有第一级元素。对于有效的XML文档,例如,刚才创
建的NorthwindCustomerOrders.xml文件,只有一个第一级元素,即根元素customers

 public void queryXml()
{
string filePath = "../../xmlFile.xml";
XDocument xdoc = XDocument.Load(filePath); var result = from item in xdoc.Elements()
select item.Name; foreach(var i in result)
{
Console.WriteLine(i);
} }

  当时如果把select item.Name 改为select.value 则显示的是所有innerText,如果改为select item ,那么显示是所有xml文档

函数二:Descendants()返回XML文档或片段中的所有子元素(所有级别的子元素)

 public void queryXmlByDescendants()
        {
            string filePath = "../../xmlFile.xml";                                <custom>
            XDocument xdoc = XDocument.Load(filePath);                              <id>1</id>
                                                                                    <name>gougou</name>
            var result = from item in xdoc.Descendants()                            <age>23</age>
                         // select item.Value; //显示所有子元素的值                </custom>
                         select item.Name;  //显示所有子元素的标签
            foreach (var i in result)
            {
                Console.WriteLine(i);
            }         }

  注意:select item.Value时,如果xml像上面右侧那样  显示的结果是1gougou23   1   gougou  23  (应该是先显示custom级的value,把下面的子节点value全部显示出来,再循环到下面的子节点,显示单个子节点的value)

当然可以加distict 除掉重复的值

foreach (var i in result.Distinct())
            {
                Console.WriteLine(i);
            }

这样就可以显示所有id的值

var result = from item in xdoc.Descendants("id")                      
                         select item.Value; //显示所有子元素的值       

函数三 Attributes(),它返回当前选中元素的所有特性

对于行如这样的xml

 <custom sequence="1" boolChange="false">
   <id>0</id>
   <name>nihao</name>
   <age>112</age>
 </custom>
  public void queryXmlByAttributes()
{
string filePath = "../../xmlFile.xml";
XDocument xdoc = XDocument.Load(filePath); var result = from item in xdoc.Descendants("custom").Attributes()
select item; //显示所有子元素的值 foreach (var i in result)
{
Console.WriteLine(i);
} }

上面代码显示的是:sequence="1"boolChange="false"

如果把 select item改为select item.name 则输出:sequence  boolchange

如果该为select item.value 则输出1 false

总结:xml的操作方法有多种,不仅可以用xml 本身提供的api,还可以用linq to xml ,各有各的好处,相比二样linq更方便

在使用之前,记得要添加:

using System.Linq;
using System.Xml.Linq
using System.Xml;

Linq学习<五> 运用linq查询Xml的更多相关文章

  1. [LINQ2Dapper]最完整Dapper To Linq框架(五)---查看Linq实际执行的SQL

    此例子是使用LINQ2Dapper封装,效率优于EntityFramwork,并且支持.NetFramework和.NetCore框架,只依赖于Dapper支持.net framework4.6.1及 ...

  2. Linq学习之旅——LINQ查询表达式

    1. 概述 2. from子句 3. where子句 4. select子句 5. group子句 6. into子句 7. 排序子句 8. let子句 9. join子句 10. 小结 1. 概述 ...

  3. Linq学习(一)-初涉Linq

    一.何谓LINQ LINQ:Language Integrated Query语言集成查询,其本质是对ADO.NET结果集通过反射连同泛型特性转换成对象集,实现OR模型的转换 二.优点与缺点 优点:封 ...

  4. LINQ学习系列-----3.1 查询非泛型集合

    一.问题起源 LINQ to object在设计时,是配合IEnumerable<T>接口的泛型集合类型使用的,例如字典.数组.List<T>等,但是对于继承了IEnumera ...

  5. LINQ学习系列-----3.1 查询非泛型集合和多个分组

    一.查询非泛型集合 1.问题起源 LINQ to object在设计时,是配合IEnumerable<T>接口的泛型集合类型使用的,例如字典.数组.List<T>等,但是对于继 ...

  6. Linq学习(五)-多表连接

    本将主要介绍 内连接与 外连接 1.join Linq to sql from a in Blog_Users join b in Blog_UserInfo on a.UserId equals b ...

  7. Oracle 数据库基础学习 (五) 多表查询

    多表查询:查询结果需要用到两个或者以上表,此时需要多表连接,产生多表查询 1.内连接(等值连接) 示例:将两个表内容连接显示 select * from dept d, emp e where d.d ...

  8. Linq学习<四> linq to XML

    LINQ to XML并不打算替代标准的XML API,例如,XML DOM(Document Object Model).Path.XQuery和XSLT等.如果熟悉这些API或当前需要使用或学习它 ...

  9. LINQ to XML LINQ学习第一篇

    LINQ to XML LINQ学习第一篇 1.LINQ to XML类 以下的代码演示了如何使用LINQ to XML来快速创建一个xml: public static void CreateDoc ...

随机推荐

  1. PHP字符串中的变量解析

    定义字符串的时候,用单引号或者双引号都是可以的.我个人习惯是用双引号.在输出字符串的时候,若字符串中含有字符串变量,使用单引号和双引号则是有区别的.如下面程序: <?php $website = ...

  2. Docker - 使用Swarm和compose部署服务(containers)

    前言 在之前使用Docker的过程中,一直是用 Docker run 命令单独启动container后再加入Overlay网络的方式实现部署工作的. 这种方式看似直接,但是随着服务所包含的contai ...

  3. iBatisNet分布式事务的应用 MS SQL2008。

    所谓分布式事务,即多台数据库服务器在一个事务中运行,因此至少两台及以上的数据库服务器. 一.所有数据库服务器必须配置好MSDTC. 如何配置请大家搜索“MSDTC配置”即可. 大至的配置为: 1.开启 ...

  4. Ubuntu16下编译linux内核,报"mkimage" command not found错的解决

    "mkimage" command not found - U-Boot images will not be built /work/system/linux-3.4.20/ar ...

  5. C++Primer笔记-----day05

    =======================================================================day05======================== ...

  6. Zabbix 监控 Mysql 状态

    简介: 如何使用 Zabbix 来监控 Mysql 状态 ? Zabbix 有自带监控 Mysql 的模板,但是却不能直接使用.. 需要我们根据模板提供的 Key 自己写脚本获取数据 1.查看都有哪些 ...

  7. JQuery easyUi datagrid 中 editor 动态设置最大值最小值

    前言 近来项目中使用到 easyui 来进行页面设计,感觉挺方便的,但是网上除了api外,其他有价值的资料比较少,故在此分享一点经验,供大家参考.   问题 JQuery easyUi datagri ...

  8. VS Code 在新Tabs打开文件

    添加如下设置即可 "workbench.editor.enablePreview": false

  9. struts2配置文件(struts.xml)中相关属性的设置

    <?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE struts PUBLIC "-/ ...

  10. 数组和集合(三):Set集合的使用总结

    一.概述 · 继承collection接口 · 无序(不记录添加顺序).不允许元素重复.只允许存在一个null元素 二.实现类 1. HashSet · 底层其实是包装了一个HashMap实现的 · ...