使用XmlDocument或XDocument可遍历XML所有节点:1. XmlDocument通过递归遍历子节点;2. XDocument用Descendants()方法简洁获取元素;3. 结合Nodes()和递归处理文本、属性及注释,推荐XDocument并注意异常处理。

在 C# 中遍历 XML 文件中的所有节点,可以使用 System.Xml 命名空间下的 XmlDocument 或 XDocument(LINQ to XML)来实现。下面介绍两种常用方法。
使用 XmlDocument 遍历所有节点
XmlDocument 提供了基于 DOM 的树结构,适合处理较复杂的 XML 操作。
通过递归方式访问每个节点:
using System; using System.Xml;class Program { static void Main() { XmlDocument doc = new XmlDocument(); doc.Load("example.xml"); // 替换为你的 XML 文件路径
TraverseNodes(doc.DocumentElement); } static void TraverseNodes(XmlNode node) { Console.WriteLine($"节点名称: {node.Name}, 节点值: {node.InnerText}"); if (node.HasChildNodes) { foreach (XmlNode child in node.ChildNodes) { TraverseNodes(child); } } }}
使用 XDocument(LINQ to XML)遍历所有节点
XDocument 是 LINQ to XML 的一部分,语法更简洁,推荐用于现代 C# 开发。
利用 Descendants() 方法获取所有子节点:
using System; using System.Linq; using System.Xml.Linq;class Program { static void Main() { XDocument doc = XDocument.Load("example.xml"); // 替换为你的文件路径
foreach (var element in doc.Descendants()) { Console.WriteLine($"元素: {element.Name}, 值: {element.Value}"); } }}
获取包含文本、属性和注释的完整节点信息
如果需要处理文本节点、属性、注释等,可结合 Nodes() 和递归遍历:
static void TraverseXNodes(XElement element)
{
Console.WriteLine($"节点类型: {element.NodeType}, 名称: {element.Name}, 值: {element.Value}");
// 输出属性
foreach (var attr in element.Attributes())
{
Console.WriteLine($" 属性: {attr.Name} = {attr.Value}");
}
foreach (var node in element.Nodes())
{
if (node is XElement subElement)
{
TraverseXNodes(subElement);
}
else
{
Console.WriteLine($" 非元素节点: {node.NodeType}, 值: {node}");
}
}}
基本上就这些。根据需求选择 XmlDocument 或 XDocument,后者更现代、易用。注意处理空值和异常(如文件不存在),确保程序健壮性。










