在C#中用XPath选中特定属性值节点需用@属性名='值'语法,XmlDocument适用于.NET Framework,XDocument(需引用System.Xml.XPath)推荐用于.NET Core/5+,注意命名空间、大小写敏感、引号转义及特殊字符处理。

在C#中使用XPath选中特定属性值的节点,核心是通过@属性名='值'语法构造XPath表达式,并配合XmlDocument或XDocument执行查询。
使用XmlDocument + SelectNodes/SelectSingleNode
适用于传统.NET Framework项目或需要兼容老代码的场景。注意XML命名空间、大小写敏感性和引号转义问题。
- 加载XML后调用
SelectNodes()(返回节点集合)或SelectSingleNode()(返回首个匹配节点) - 属性匹配写法:例如
"//book[@category='fiction']"选中所有中category属性值为fiction的节点 - 若属性值含单引号,改用双引号包裹XPath;含双引号则用单引号包裹,或使用
concat()函数拼接 - 示例:
doc.SelectNodes("//user[@id='1024' and @active='true']")可同时匹配多个属性条件
使用XDocument + XPathSelectElements/XPathSelectElement
推荐用于.NET Core/.NET 5+项目,需引用System.Xml.XPath.XDocument扩展包(.NET Standard 2.0+已内置)。
- 调用
XDocument.XPathSelectElements(string xpath)获取IEnumerable - 支持更现代的XPath 1.0语法,写法与
XmlDocument基本一致,如"//product[@inStock='yes']" - 对命名空间敏感——若XML有默认命名空间,必须注册
XNamespace并参与查询,否则查不到节点 - 示例:
var ns = XNamespace.Get("http://example.com/ns"); doc.XPathSelectElements($"//{ns}item[@type='book']")
处理常见陷阱
实际使用中容易因细节出错,重点关注以下几点:
-
属性名和值严格区分大小写:XPath中
@Class≠@class,XML源中怎么写就怎么查 -
空格和前后缀不影响匹配:但属性值本身含空格时需完整写出,如
@role=' admin '只能匹配值两端带空格的节点 -
特殊字符需转义:属性值含
&、等,应在原始XML中已实体化(如&),XPath中直接写"@desc='C&C++'" -
通配符可用但谨慎:如
"//node[@id[starts-with(.,'U_')]]"匹配id以U_开头的节点,避免过度使用//影响性能
完整小例子(XDocument方式)
假设XML字符串为:
var target = doc.XPathSelectElement("//item[@type='widget']");
if (target != null) Console.WriteLine(target.Value); // 输出 "OK"










