答案:在C#中使用XmlDocument类结合XPath可查询XML节点。首先加载XML文件,通过SelectNodes获取多个节点或SelectSingleNode查找单个节点,支持按属性、文本内容等条件筛选,需注意XML格式正确、路径大小写敏感及命名空间处理。

在C#中使用XPath查询XML节点,可以通过 System.Xml 命名空间中的 XmlDocument 或 XDocument 类来实现。下面以 XmlDocument 为例,介绍如何加载XML并使用XPath查找节点。
1. 使用 XmlDocument 和 SelectNodes 查询多个节点
假设有一个如下结构的XML文件:
你可以使用以下代码通过XPath查询所有 Book 节点:
using System; using System.Xml;XmlDocument doc = new XmlDocument(); doc.Load("books.xml"); // 或者使用 LoadXml("字符串")
XmlNodeList bookNodes = doc.SelectNodes("/Books/Book");
新普网店系统XpShop.net(捆绑集成Discuz 2.0论坛)下载新普网店系统XpShop完美结合Discuz 2.0版本论坛。论坛可以到Discuz官方网站或者到XpShop官方网站下载,集成方法请到XpShop官方网站论坛查询软件特点介绍:1、使用ASP.Net(c#)、三层结构开发2、自由选择模板,界面美观,皮肤设计灵活多变3、在线支付:支付宝,网银在线,快钱,paypal,YeePay易宝支付,IPS环讯支付,腾讯财付通4、销售统计,图表分析5、集成多种
foreach (XmlNode node in bookNodes) { string title = node["Title"]?.InnerText; string author = node["Author"]?.InnerText; Console.WriteLine($"标题: {title}, 作者: {author}"); }
2. 使用 SelectSingleNode 查询单个节点
如果你想根据条件查询特定节点,比如查找 ID 为 "2" 的 Book:
XmlNode bookNode = doc.SelectSingleNode("/Books/Book[@ID='2']");
if (bookNode != null)
{
string title = bookNode["Title"]?.InnerText;
Console.WriteLine($"找到书籍: {title}");
}
XPath 中的 @ID='2' 表示匹配属性 ID 值为 "2" 的节点。
3. 常用 XPath 表达式示例
- /Books/Book[1]:选择第一个 Book 节点(索引从1开始)
- //Title:选择文档中所有 Title 节点(不管层级)
- /Books/Book[Title='C# 入门']:选择 Title 为 "C# 入门" 的 Book
- /Books/Book/@ID:选择所有 Book 节点的 ID 属性节点
- /Books/Book/Author[text()='李四']:选择 Author 文本内容为“李四”的节点
4. 注意事项
- 确保XML格式正确,否则 Load 会抛出异常。
- 使用 SelectSingleNode 找不到节点时返回 null,记得判空。
- XPath 区分大小写,路径书写要准确。
- 如果XML有命名空间,需要使用 XmlNamespaceManager 设置前缀,否则查询可能失败。
基本上就这些。XPath配合 XmlDocument 可以高效定位和提取XML数据,适合配置解析或数据读取场景。










