C#使用Linq to XML进行XPath查询的代码实现

 更新时间:2024年08月14日 10:13:42   作者:△曉風殘月〆  
最近在用到HtmlAgliltyPack进行结点查询时,发现这里选择结点使用的是XPath,所以这里总结一下在C#中使用XPath查询XML的方法,习惯了用Linq,这里也是用的Linq to xml的,需要的朋友可以参考下

最近在用到HtmlAgliltyPack进行结点查询时,发现这里选择结点使用的是XPath。所以这里总结一下在C#中使用XPath查询XML的方法。习惯了用Linq,这里也是用的Linq to xml的。

Linq To XML的核心类是XDocumentXElementXAttribute,需要引用using System.Xml.Linq命名空间。

这三个类简单理解为:

XDocument:打开的整个XML文档

XElement:节点元素

XAttribute:属性

下面简单介绍一下使用

如有以下XML文件

  <?xml version="1.0" encoding="utf-8"?>
  <html>
    <head>
      <title>测试XML</title>
    </head>
    <body>
      <div class="card-container">
        <div class="item-title">
          <h3 class="item-shop-name">汪家羊肉馆</h3>
        </div>
        <div class="item-comment">
          <span class="price1">¥62/人</span>
          <span class="price2">¥12/人</span>
          <span class="price3">2</span>
          <span class="price4">12</span>
        </div>
      </div>
    </body>
  </html>

打开XML文件

XDocument doc = XDocument.Load("demo.xml");

获取根节点(html节点 返回XElement类型)

var root = doc.Root;

获取第一个子节点(返回XElement类型)

var firstNode = root.FirstNode;

获取全部子节点(返回IEnumerable<XNode>)

var allChildNode = root.Nodes();

获取指定名称的第一个子节点(返回XElement类型)

var headNode = root.Element("head");

获取指定名称的全部子节点(返回IEnumerable<XElement>)

var allNamedNode = root.Elements("head");

获取节点指定名称的属性(<div class="card-container"> )

var attribute = root.Element("body").Element("div").Attribute("class");

获取节点的全部属性

var allAttributes = root.Attributes();

使用XPath查询(需要引用using System.Xml.XPath命名空间)

var xpathQeury = root.XPathSelectElement("body/div");

获取节点的名称和值

   //获取结点的名称
    var nodeName = root.Name;
    //获取节点的值
    var nodeValue = root.Value;

保存XML

doc.Save("demo.xml");

Linq查询(获取<span class="price2">¥12/人</span>节点下的值)

这里仅做示例,返回返回IEnumerable<XElement>类型的都可以进行Linq查询

不使用XPath

 var queryResult = root.Element("body").Element("div").Elements("div").ElementAt(1).Elements("span").Where(x=>x.Attribute("class") != null && x.Attribute("class").Value == "price2").FirstOrDefault();
             if(queryResult != null)
                 Console.WriteLine(queryResult.Value);

使用XPath

 var xpathQueryResult = root.XPathSelectElements("body/div/div[2]/span").Where(x => x.Attribute("class") != null && x.Attribute("class").Value == "price2").FirstOrDefault();
             if(xpathQueryResult != null)
                 Console.WriteLine(xpathQueryResult.Value);

输出结果都为下

下面开始介绍XPath

XPath 是 XML 文档中查找信息的语言,使用XPath可以对XML的元素进行查找。

这里重着介绍一下XPath语法

/    从根节点开始选择

 var xpathRoot = doc.XPathSelectElement("/html");
 var xpathRoot2 = doc.XPathSelectElement("html");

运行结果

//   获取文档中所有指定的结点,不管它的位置

如要获取xml文档中所有的span节点

             //以下获取的结果都是一样的
             //尽管位置不一样,但查询结果是一样的
             var body = root.Element("body").Element("div").Elements("div").ElementAt(1);
             var allDivNodeInBody = body.XPathSelectElements("//div");
             var allDivNodeInDoc = doc.XPathSelectElements("//div");
             Console.WriteLine(allDivNodeInBody.Count());
             Console.WriteLine(allDivNodeInDoc.Count());

运行结果

.当前节点

var currentNode = root.XPathSelectElement(".");

运行结果

..当前节点的父节点

var parentNode = root.Element("body").XPathSelectElement("..");

运行结果

@  选取属性

这个操作在Linq to xml里不支持,会产生一个"XPath 表达式的计算结果为意外类型 System.Xml.Linq.XAttribute。"异常

通配查询 *     全部节点 @*  全部属性(不支持)

谓词查询 选择第一个查询结果,如<span class="price1">¥62/人</span>

var firstSpanNode = doc.XPathSelectElement("//span[1]");

运行结果

选择最后一个查询结果,如最后一个<span class="price4">12</span>

 var lastDivNode = doc.XPathSelectElement("//span[last()]");
 Console.WriteLine(lastDivNode.Attribute("class").Value);

运行结果

选择带有属性class的div节点

 var nodeWithClassAttribute = doc.XPathSelectElements("//div[@class]");
             foreach (var item in nodeWithClassAttribute)
             {
                 Console.WriteLine("====================");
                 Console.WriteLine(item);
             }

运行结果

选择带有属性class,且值为item-title的div节点

  var nodeWithClassValueAttribute = doc.XPathSelectElements("//div[@class='item-title']");
             foreach (var item in nodeWithClassValueAttribute)
             {
                 Console.WriteLine(item);
             }

运行结果

简单的选择计算 获取倒数第二个div节点

var nextToLastDivNode = doc.XPathSelectElement("//div[last()-1]");

运行结果

获取值大于10的span节点

var greaterThanTenSpan = doc.XPathSelectElements("//span[text()>10]");

运行结果:

获取值加10等于22的span节点

var plusTenSpan = doc.XPathSelectElements("//span[text()+10=22]");

运行结果:

常用运行符如下

+               加

-                减

*               乘

div           除

=              等于

!=             不等于

>              大于

<              小于

>=           大于等于

<=            小于等于

or            或

and          与

组合查询

如查询值等于12或等于2的span节点

  var combineQuery = doc.XPathSelectElements("//span[text()=2]|//span[text()=12]");
             foreach (var item in combineQuery)
             {
                 Console.WriteLine(item.Value);
             }

运行结果

以上就是C#使用Linq to XML进行XPath查询的代码实现的详细内容,更多关于C# Linq to XML进行XPath查询的资料请关注脚本之家其它相关文章!

相关文章

  • C#实现应用程序的监控与调试的示例代码

    C#实现应用程序的监控与调试的示例代码

    日志记录是软件开发中不可或缺的功能,它能帮助开发者在应用程序运行时记录重要信息,本文就来介绍一下常用日志记录功能以及常用的日志库,感兴趣的可以了解一下
    2024-03-03
  • C#实现图片上传与浏览切换的方法

    C#实现图片上传与浏览切换的方法

    这篇文章主要介绍了C#实现图片上传与浏览切换的方法,是很有实用价值的一个应用技巧,需要的朋友可以参考下
    2014-08-08
  • C#实现滑动开关效果

    C#实现滑动开关效果

    这篇文章主要为大家详细介绍了C#实现滑动开关效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C#实现从PPT中提取文本的示例代码

    C#实现从PPT中提取文本的示例代码

    今天这篇文章主要为大家详细介绍了如何通过编程方式提取PowerPoint中的文字,文章最后附有C#/VB.NET代码以及效果图,希望对你有所帮助
    2023-05-05
  • c#的异或运算符介绍

    c#的异或运算符介绍

    这篇文章介绍了c#的异或运算符,有需要的朋友可以参考一下
    2013-11-11
  • C#实现加密exe文件

    C#实现加密exe文件

    这篇文章主要为大家详细介绍了C#如何实现加密exe文件的功能,文中的示例代码讲解详细,对我们学习C#有一定的帮助,感兴趣的小伙伴可以跟随小编一起了解一下
    2023-01-01
  • C# 解决在Dictionary中使用枚举的效率问题

    C# 解决在Dictionary中使用枚举的效率问题

    这篇文章主要介绍了C# 解决在Dictionary中使用枚举的效率问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • C#集合之集(set)的用法

    C#集合之集(set)的用法

    这篇文章介绍了C#集合之集(set)的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • C#利用OLEDB实现将DataTable写入Excel文件中

    C#利用OLEDB实现将DataTable写入Excel文件中

    这篇文章主要为大家详细介绍了C#如何利用OLEDB实现将DataTable写入Excel文件中,文中的示例代码简洁易懂,具有一定的借鉴价值,需要的可以参考一下
    2023-02-02
  • 解析如何正确使用SqlConnection的实现方法

    解析如何正确使用SqlConnection的实现方法

    本篇文章对如何正确使用SqlConnection的实现方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05

最新评论