答案:在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、集成多种
0
![]()
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数据,适合配置解析或数据读取场景。
以上就是C# 使用XPath查询xml节点的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1440982.html
微信扫一扫
支付宝扫一扫