使用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,后者更现代、易用。注意处理空值和异常(如文件不存在),确保程序健壮性。
以上就是C# 如何遍历xml文件中的所有节点的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1441018.html
微信扫一扫
支付宝扫一扫