0

0

C# 使用LINQ to XML查询xml数据

星降

星降

发布时间:2025-11-05 20:30:05

|

634人浏览过

|

来源于php中文网

原创

LINQ to XML可在C#中高效查询和操作XML,支持从文件或字符串加载数据,使用XDocument.Load或Parse方法;通过Elements、Element和Attribute方法结合LINQ语法可实现标题提取、条件筛选及属性读取;支持命名空间处理,使XML操作简洁直观。

c# 使用linq to xml查询xml数据

在C#中,使用LINQ to XML可以非常方便地查询和操作XML数据。它结合了LINQ的强大查询能力与轻量级的XML处理机制,语法简洁、易读性强。

加载XML数据

你可以从字符串、文件或流中加载XML数据。常用的是XDocument.Load(从文件)或XDocument.Parse(从字符串)。

示例XML:


  
    C#入门经典
    张三
    69.00
  

  
    深入理解LINQ
    李四
    89.50
  

加载方式:

var doc = XDocument.Load("books.xml");
// 或从字符串解析
var doc = XDocument.Parse(xmlString);

基本查询:获取所有书籍标题

使用Elements()Element()方法结合LINQ查询。

var titles = from book in doc.Root.Elements("Book")
        select book.Element("Title").Value;

foreach (var title in titles)
    Console.WriteLine(title);

带条件的查询:查找价格大于70的书籍

在查询中加入where子句进行筛选。

中小企业网站系统前台源码(SmallBusinessStarterKit)
中小企业网站系统前台源码(SmallBusinessStarterKit)

小型企业入门套件(The Small Business Starter Kit)提供了一个商业宣传网站的完整演示,他适合中小型企业。使用他创建的网站支持自定义模板,具有先进的功能,包括:内容和数据管理的SQL和XML数据源整合。该源码包含C#和VB两个版本,只有前台部分源码,微软官方截止到51aspx发布源码时还没有提供后台代码。小型企业网站入门套件的关键页面包括:产品分类显示新闻发布显示商户认证

下载
var expensiveBooks = from book in doc.Root.Elements("Book")
               where decimal.Parse(book.Element("Price").Value) > 70
               select new
               {
                  Title = book.Element("Title").Value,
                  Author = book.Element("Author").Value,
                  Price = decimal.Parse(book.Element("Price").Value)
               };

foreach (var book in expensiveBooks)
    Console.WriteLine($"{book.Title} - {book.Author} : {book.Price}");

查询属性:获取Book的ID

使用Attribute()方法读取节点属性。

var booksWithId = from book in doc.Root.Elements("Book")
               select new
               {
                  ID = book.Attribute("ID")?.Value,
                  Title = book.Element("Title").Value
               };

注意:使用 ?. 可避免Attribute为null时报错。

处理命名空间(如有)

如果XML包含命名空间,需先定义XNamespace

XNamespace ns = "http://example.com/books";
var books = from book in doc.Root.Elements(ns + "Book")
              select book.Element(ns + "Title").Value;

基本上就这些。LINQ to XML让XML查询变得像写SQL一样自然,适合中小规模数据的读取和转换。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

673

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

344

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1082

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

355

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

671

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

563

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

406

2024.04.29

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 5.4万人学习

C 教程
C 教程

共75课时 | 3.7万人学习

C++教程
C++教程

共115课时 | 10万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号