C#如何遍历一个XML文件的所有节点和属性

来源:网络学院作者:冷风头衔:草根站长
导读:本期聚焦于小伙伴创作的《C#如何遍历一个XML文件的所有节点和属性》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《C#如何遍历一个XML文件的所有节点和属性》有用,将其分享出去将是对创作者最好的鼓励。

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

C#如何遍历一个XML文件的所有节点和属性

准备工作

首先需要引入处理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

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