C#中如何读取xml文件 LINQ to XML的五种常用查询技巧

来源:我的博客作者:重启一下头衔:草根站长
导读:本期聚焦于小伙伴创作的《C#中如何读取xml文件 LINQ to XML的五种常用查询技巧》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《C#中如何读取xml文件 LINQ to XML的五种常用查询技巧》有用,将其分享出去将是对创作者最好的鼓励。

在C#开发中,处理xml格式的数据是很多项目都会遇到的场景,LINQ to XML是.NET Framework 3.5之后推出的xml处理技术,相比传统的XmlDocument方式,它的语法更简洁,和LINQ查询结合后能让xml数据的读取和筛选变得更高效。下面先介绍基础的xml文件读取方式,再讲解五种常用的查询技巧。

C#中如何读取xml文件 LINQ to XML的五种常用查询技巧

一、C#中读取xml文件的基础操作

使用LINQ to XML读取xml文件,首先需要引入System.Xml.Linq命名空间,然后通过XDocument类的Load方法加载本地xml文件,或者Parse方法加载xml字符串。下面是加载本地xml文件的示例代码,假设我们有一个存放学生信息的students.xml文件,内容如下:

<?xml version="1.0" encoding="utf-8"?>
<Students>
  <Student Id="1">
    <Name>张三</Name>
    <Age>20</Age>
    <Class>计算机1班</Class>
  </Student>
  <Student Id="2">
    <Name>李四</Name>
    <Age>21</Age>
    <Class>计算机1班</Class>
  </Student>
  <Student Id="3">
    <Name>王五</Name>
    <Age>20</Age>
    <Class>计算机2班</Class>
  </Student>
</Students>

加载这个xml文件的C#代码如下:

using System;
using System.Xml.Linq;

class Program
{
    static void Main()
    {
        // 加载本地xml文件,路径根据实际情况修改
        XDocument doc = XDocument.Load("students.xml");
        // 验证是否加载成功,输出根节点名称
        Console.WriteLine("根节点名称:" + doc.Root.Name);
    }
}

二、LINQ to XML的五种常用查询技巧

1. 查询单个指定节点

如果需要获取xml中第一个符合条件的节点,可以使用Descendants方法配合FirstOrDefault完成。比如查询第一个学生的姓名:

// 查询第一个Student节点下的Name节点内容
XElement firstStudentName = doc.Descendants("Student")
                               .FirstOrDefault()
                               ?.Element("Name");
if (firstStudentName != null)
{
    Console.WriteLine("第一个学生姓名:" + firstStudentName.Value);
}

2. 筛选多节点数据

当需要获取所有符合某个条件的节点时,可以使用Where筛选。比如查询所有年龄为20的学生信息:

// 查询所有Age为20的Student节点
var age20Students = doc.Descendants("Student")
                       .Where(s => s.Element("Age")?.Value == "20");
Console.WriteLine("年龄为20的学生:");
foreach (var student in age20Students)
{
    string name = student.Element("Name")?.Value;
    string className = student.Element("Class")?.Value;
    Console.WriteLine($"姓名:{name},班级:{className}");
}

3. 查询节点属性值

xml节点的属性可以通过Attribute方法获取,比如查询所有学生的Id属性:

// 查询所有Student节点的Id属性值
var studentIds = doc.Descendants("Student")
                    .Select(s => s.Attribute("Id")?.Value);
Console.WriteLine("所有学生Id:");
foreach (var id in studentIds)
{
    Console.WriteLine(id);
}

4. 嵌套节点查询

当xml结构存在多层嵌套时,可以通过逐层访问的方式查询数据,比如查询计算机1班的所有学生姓名:

// 查询Class为计算机1班的学生的姓名
var class1Students = doc.Descendants("Student")
                        .Where(s => s.Element("Class")?.Value == "计算机1班")
                        .Select(s => s.Element("Name")?.Value);
Console.WriteLine("计算机1班的学生姓名:");
foreach (var name in class1Students)
{
    Console.WriteLine(name);
}

5. 聚合查询

结合LINQ的聚合方法,可以对xml中的数据做统计,比如查询学生的平均年龄:

// 查询所有学生的平均年龄
var avgAge = doc.Descendants("Student")
                .Select(s => int.Parse(s.Element("Age")?.Value ?? "0"))
                .Average();
Console.WriteLine("学生平均年龄:" + avgAge);

三、注意事项

在使用LINQ to XML查询时,需要注意节点或属性可能不存在的情况,建议配合空条件运算符?.使用,避免出现空引用异常。另外,如果xml文件较大,频繁使用Descendants方法遍历所有后代节点可能影响性能,此时可以根据已知的节点层级,使用Element方法逐层访问,减少遍历范围。

LINQ_to_XMLC#xml读取XML查询System.Xml.Linq修改时间:2026-06-27 23:54:30

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。