如何在C#中使用XmlDocument类加载和遍历XML文件?

小老鼠
发布: 2025-07-30 13:20:02
原创
965人浏览过

xmldocument类是c#中用于加载、修改和保存xml文档的核心类。1. 常用方法和属性包括:load()从文件加载xml,loadxml()从字符串加载,save()保存文档,documentelement获取根元素,createelement()和createattribute()创建节点和属性,selectsinglenode()和selectnodes()通过xpath查询节点,innerxml和innertext操作节点内容。2. 使用xpath查询特定节点:可通过selectsinglenode()和selectnodes()方法结合xpath表达式定位节点,如"/bookstore/book"选择所有book元素,"/bookstore/book[@category='cooking']"选择指定属性的book元素,"//title"选择所有title元素。3. 递归遍历所有节点:可编写递归函数traversenodes()遍历每个节点并执行操作,通过判断haschildnodes并循环调用子节点实现完整遍历,适用于需要深度处理的场景。

如何在C#中使用XmlDocument类加载和遍历XML文件?

XmlDocument 类是 C# 中处理 XML 文档的核心类之一。它允许你加载、修改和保存 XML 数据。加载 XML 文件并遍历其节点是常见的任务,本文将详细介绍如何使用 XmlDocument 类来实现这些功能。

解决方案

  1. 加载 XML 文件: 使用 XmlDocument 类的 Load() 方法从文件、Stream 或 TextReader 中加载 XML 数据。
  2. 遍历 XML 节点: 使用 SelectSingleNode()SelectNodes() 或递归方法来访问和处理 XML 文档中的节点。

副标题1:XmlDocument 类有哪些常用的方法和属性?

XmlDocument 类提供了丰富的方法和属性,用于操作 XML 文档。以下是一些常用的:

  • Load(string filename): 从指定的文件加载 XML 文档。
  • LoadXml(string xml): 从字符串加载 XML 文档。
  • Save(string filename): 将 XML 文档保存到指定的文件。
  • DocumentElement: 获取 XML 文档的根元素。
  • CreateElement(string name): 创建一个新的元素节点。
  • CreateAttribute(string name): 创建一个新的属性节点。
  • SelectSingleNode(string xpath): 使用 XPath 表达式选择单个节点。
  • SelectNodes(string xpath): 使用 XPath 表达式选择多个节点。
  • InnerXml: 获取或设置节点的内部 XML 标记。
  • InnerText: 获取或设置节点及其所有子节点的文本内容。

例如,创建新元素并添加到文档中:

XmlDocument doc = new XmlDocument();
XmlElement root = doc.CreateElement("root");
doc.AppendChild(root);

XmlElement element = doc.CreateElement("child");
element.InnerText = "Child Element Content";
root.AppendChild(element);

doc.Save("new_xml.xml");
登录后复制

副标题2:如何使用 XPath 查询 XML 文档中的特定节点?

XPath 是一种用于在 XML 文档中定位节点的查询语言。XmlDocument 类的 SelectSingleNode()SelectNodes() 方法可以使用 XPath 表达式来选择节点。

超级简历WonderCV
超级简历WonderCV

免费求职简历模版下载制作,应届生职场人必备简历制作神器

超级简历WonderCV28
查看详情 超级简历WonderCV

例如,假设有以下 XML 文档:

<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
  <book category="COOKING">
    <title lang="en">Everyday Italian</title>
    <author>Giada De Laurentiis</author>
    <year>2005</year>
    <price>30.00</price>
  </book>
  <book category="CHILDREN">
    <title lang="en">Harry Potter</title>
    <author>J.K. Rowling</author>
    <year>2005</year>
    <price>29.99</price>
  </book>
</bookstore>
登录后复制

可以使用以下 XPath 表达式来查询节点:

  • "/bookstore/book": 选择所有 book 元素。
  • "/bookstore/book[@category='COOKING']": 选择 category 属性为 "COOKING" 的 book 元素。
  • "/bookstore/book/title": 选择所有 book 元素下的 title 元素。
  • "//title": 选择文档中所有 title 元素(不考虑层级关系)。

以下 C# 代码演示了如何使用 XPath 查询 XML 文档:

XmlDocument doc = new XmlDocument();
doc.Load("books.xml");

XmlNodeList bookNodes = doc.SelectNodes("/bookstore/book");
Console.WriteLine($"找到 {bookNodes.Count} 本书");

XmlNode cookingBook = doc.SelectSingleNode("/bookstore/book[@category='COOKING']");
if (cookingBook != null)
{
    Console.WriteLine($"烹饪书的标题:{cookingBook.SelectSingleNode("title").InnerText}");
}
登录后复制

副标题3:如何递归遍历 XML 文档的所有节点?

除了使用 XPath,还可以使用递归方法遍历 XML 文档的所有节点。递归方法可以访问文档中每个节点,并执行相应的操作。

static void TraverseNodes(XmlNode node)
{
    Console.WriteLine($"Node Name: {node.Name}, Value: {node.Value}");

    if (node.HasChildNodes)
    {
        foreach (XmlNode childNode in node.ChildNodes)
        {
            TraverseNodes(childNode); // 递归调用
        }
    }
}
登录后复制

使用示例:

XmlDocument doc = new XmlDocument();
doc.Load("books.xml");

TraverseNodes(doc.DocumentElement);
登录后复制

这个递归函数会打印出 XML 文档中每个节点的名称和值。你可以根据需要修改此函数,执行其他操作,例如提取特定信息或修改节点属性。这种方法灵活,但需要注意避免无限递归,确保逻辑正确。

以上就是如何在C#中使用XmlDocument类加载和遍历XML文件?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号