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

在C#中使用XPath查询XML节点,可以通过 System.Xml 命名空间中的 XmlDocument 或 XDocument 类来实现。下面以 XmlDocument 为例,介绍如何加载XML并使用XPath查找节点。
假设有一个如下结构的XML文件:
<Books>你可以使用以下代码通过XPath查询所有 Book 节点:
using System;
using System.Xml;
<p>XmlDocument doc = new XmlDocument();
doc.Load("books.xml"); // 或者使用 LoadXml("字符串")</p><p>XmlNodeList bookNodes = doc.SelectNodes("/Books/Book");</p>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/ai/2326">
<img src="https://img.php.cn/upload/ai_manual/001/246/273/175877042283856.png" alt="造点AI">
</a>
<div class="aritcle_card_info">
<a href="/ai/2326">造点AI</a>
<p>夸克 · 造点AI</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="造点AI">
<span>325</span>
</div>
</div>
<a href="/ai/2326" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="造点AI">
</a>
</div>
<p>foreach (XmlNode node in bookNodes)
{
string title = node["Title"]?.InnerText;
string author = node["Author"]?.InnerText;
Console.WriteLine($"标题: {title}, 作者: {author}");
}
如果你想根据条件查询特定节点,比如查找 ID 为 "2" 的 Book:
XmlNode bookNode = doc.SelectSingleNode("/Books/Book[@ID='2']");
<p>if (bookNode != null)
{
string title = bookNode["Title"]?.InnerText;
Console.WriteLine($"找到书籍: {title}");
}
XPath 中的 @ID='2' 表示匹配属性 ID 值为 "2" 的节点。
基本上就这些。XPath配合 XmlDocument 可以高效定位和提取XML数据,适合配置解析或数据读取场景。
以上就是C# 使用XPath查询xml节点的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号