在C#开发中,处理XML文件是常见的需求,遍历XML的所有节点和属性可以让我们完整获取文件中的数据信息。下面介绍基于XmlDocument类的遍历实现方法。

准备工作
首先需要引入处理XML相关的命名空间,在代码文件顶部添加如下引用:
using System.Xml;
加载XML文件
使用XmlDocument类可以方便加载和解析XML文件,首先创建实例并加载目标XML文件:
// 创建XmlDocument实例
XmlDocument xmlDoc = new XmlDocument();
// 加载指定路径的XML文件,这里替换为实际的XML文件路径
xmlDoc.Load("test.xml");
// 也可以加载XML字符串,使用xmlDoc.LoadXml(xmlString);方法
遍历所有节点和属性
遍历XML节点需要使用递归的方式,因为XML的节点是树形结构,可能存在多层嵌套。同时每个节点可能包含多个属性,需要单独遍历属性集合。
递归遍历节点的实现
首先编写一个递归方法,用于处理当前节点及其所有子节点:
/// <summary>
/// 递归遍历XML节点
/// </summary>
/// <param name="node">当前处理的XML节点</param>
/// <param name="depth">当前节点的深度,用于缩进显示</param>
private static void TraverseNode(XmlNode node, int depth)
{
// 跳过空白节点,避免无意义输出
if (node.NodeType == XmlNodeType.Whitespace)
{
return;
}
// 拼接缩进字符串,方便查看层级结构
string indent = new string(' ', depth * 2);
// 输出当前节点的名称和类型
Console.WriteLine($"{indent}节点名称:{node.Name},节点类型:{node.NodeType}");
// 如果节点有值,输出节点值
if (!string.IsNullOrEmpty(node.Value))
{
Console.WriteLine($"{indent}节点值:{node.Value}");
}
// 遍历当前节点的所有属性
if (node.Attributes != null)
{
foreach (XmlAttribute attr in node.Attributes)
{
Console.WriteLine($"{indent}属性:{attr.Name} = {attr.Value}");
}
}
// 递归遍历当前节点的所有子节点
if (node.HasChildNodes)
{
foreach (XmlNode childNode in node.ChildNodes)
{
TraverseNode(childNode, depth + 1);
}
}
}
调用遍历方法
加载XML文件后,从根节点开始调用递归方法即可完成所有节点和属性的遍历:
try
{
XmlDocument xmlDoc = new XmlDocument();
// 加载XML文件,替换为实际文件路径
xmlDoc.Load("test.xml");
// 从根节点开始遍历,初始深度为0
TraverseNode(xmlDoc.DocumentElement, 0);
}
catch (Exception ex)
{
Console.WriteLine($"处理XML文件时出现错误:{ex.Message}");
}
测试XML示例
可以准备如下的测试XML文件来验证遍历效果:
<?xml version="1.0" encoding="utf-8"?>
<root>
<user id="1" name="张三" age="25">
<address>北京市海淀区</address>
<hobby>编程</hobby>
</user>
<user id="2" name="李四" age="30">
<address>上海市浦东新区</address>
<hobby>阅读</hobby>
</user>
</root>
注意事项
- 遍历前需要判断节点是否包含属性,避免
Attributes属性为null导致异常 - 空白节点可以按需过滤,减少无意义的输出
- 如果XML文件较大,递归深度过深可能导致栈溢出,此时可以考虑使用栈结构实现非递归遍历
- 处理XML时注意捕获异常,避免文件不存在、格式错误等问题导致程序崩溃
C#XMLXmlDocument递归遍历节点属性修改时间:2026-06-17 12:12:20