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

星降
发布: 2025-11-05 20:30:05
原创
634人浏览过
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发布源码时还没有提供后台代码。小型企业网站入门套件的关键页面包括:产品分类显示新闻发布显示商户认证

中小企业网站系统前台源码(SmallBusinessStarterKit) 0
查看详情 中小企业网站系统前台源码(SmallBusinessStarterKit)
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一样自然,适合中小规模数据的读取和转换。

以上就是C# 使用LINQ to XML查询xml数据的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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