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