XPathNavigator 查询 XML 高效,推荐用 XPathDocument 创建;优先调用 MoveToXXX 方法和 Value 属性;高频查询需预编译 XPathExpression。

使用 XPathNavigator 查询 XML 在 C# 中确实高效,尤其适合只读、随机访问或需要 XPath 表达式灵活性的场景。它的核心优势在于基于光标(cursor)的快速移动和原生 XPath 支持,避免了反复加载 DOM 或构建完整对象树的开销。
前提:正确创建可导航的 XPathNavigator
不能直接 new XPathNavigator,必须从支持 XPath 的源创建。最常用的是 XPathDocument(只读、轻量、专为查询优化)或 XmlDocument(可读写但稍重):
- 推荐用
XPathDocument:构造时已内部优化索引结构,CreateNavigator()返回的 navigator 查询速度更快,内存占用更低 - 避免用
XmlDocument.CreateNavigator()做高频只读查询——它会保留完整 DOM 树,不必要地消耗内存 - 示例:
var doc = new XPathDocument("data.xml"); var nav = doc.CreateNavigator();
精准定位:用 MoveToXXX 方法代替 Select + 循环遍历
很多人习惯 Select() 返回节点集再 foreach,其实对单个目标节点,MoveToXXX 系列方法更高效(避免创建中间迭代器和节点集合):
25175企业客户管理系统能够方便的录入新的信息例如新的项目、新增客户等同时能够清楚的管理一些款项结算。由于功能的强大,用户可以在该系统上发表文章后让员工递交工作计划或工作报告。加强企业工作效率,为企业提高实力。因为该系统可由客户、程序员、负责人等身份登入 所以适合广大企业使用。管理首页:{信息录入|信息修改|信息查询}1信息录入:你可以根据实际情况进行以下操作 1-1新的项目
-
nav.MoveToRoot()快速回到文档根 -
nav.MoveToFirstChild()、nav.MoveToNext()、nav.MoveToParent()等做局部移动,开销极小 - 若已知路径如
/bookstore/book[1]/title,直接nav.SelectSingleNode("/bookstore/book[1]/title")比先 Select 再取 [0] 更快
高效提取值:优先用 Value 属性,慎用 InnerXml/OuterXml
获取文本内容时,Value 属性返回合并后的纯文本(自动跳过注释、处理指令等),性能远高于 InnerXml(需序列化子节点):
- 要取元素内容(如
的 "29.99")→ 用29.99 nav.Value - 要取带格式的子 XML 字符串 → 才用
InnerXml,但注意它触发序列化,有额外开销 - 用
GetAttribute("name", "")直接取属性值,比先定位属性节点再读 Value 更简洁
批量查询:用 Compile + Execute 预编译 XPath 表达式
如果同一 XPath 表达式在循环中多次执行(比如查 1000 个 book 的 author),务必预编译,避免每次解析字符串:
XPathExpression expr = XPathExpression.Compile("//book/author");- 之后循环中:
nav.Select(expr)或nav.SelectSingleNode(expr) - 预编译后执行速度提升明显,尤其复杂表达式;且可复用,线程安全









