通八洲科技

C#如何使用XPathNavigator高效查询XML

日期:2026-01-02 00:00 / 作者:幻夢星雲
XPathNavigator 查询 XML 高效,推荐用 XPathDocument 创建;优先调用 MoveToXXX 方法和 Value 属性;高频查询需预编译 XPathExpression。

使用 XPathNavigator 查询 XML 在 C# 中确实高效,尤其适合只读、随机访问或需要 XPath 表达式灵活性的场景。它的核心优势在于基于光标(cursor)的快速移动和原生 XPath 支持,避免了反复加载 DOM 或构建完整对象树的开销。

前提:正确创建可导航的 XPathNavigator

不能直接 new XPathNavigator,必须从支持 XPath 的源创建。最常用的是 XPathDocument(只读、轻量、专为查询优化)或 XmlDocument(可读写但稍重):

精准定位:用 MoveToXXX 方法代替 Select + 循环遍历

很多人习惯 Select() 返回节点集再 foreach,其实对单个目标节点,MoveToXXX 系列方法更高效(避免创建中间迭代器和节点集合):

高效提取值:优先用 Value 属性,慎用 InnerXml/OuterXml

获取文本内容时,Value 属性返回合并后的纯文本(自动跳过注释、处理指令等),性能远高于 InnerXml(需序列化子节点):

批量查询:用 Compile + Execute 预编译 XPath 表达式

如果同一 XPath 表达式在循环中多次执行(比如查 1000 个 book 的 author),务必预编译,避免每次解析字符串: