.NET怎么生成和解析XML文件

来源:站长站作者:唐僧头衔:草根站长
导读:本期聚焦于小伙伴创作的《.NET怎么生成和解析XML文件》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《.NET怎么生成和解析XML文件》有用,将其分享出去将是对创作者最好的鼓励。

在.NET开发场景中,XML作为轻量且结构清晰的数据格式,常被用于配置文件存储、跨系统数据交互等场景,掌握XML文件的生成与解析方法是开发者的必备技能。.NET框架提供了多套XML处理API,开发者可以根据项目需求选择合适的实现方式。

使用XmlDocument生成XML文件

XmlDocument是.NET早期提供的XML文档操作类,基于DOM模型实现,适合需要频繁修改节点结构的场景。生成XML的核心步骤是创建文档对象、构建节点层级、最后保存为文件。

using System.Xml;

// 创建XmlDocument对象
XmlDocument xmlDoc = new XmlDocument();
// 创建XML声明节点
XmlDeclaration xmlDecl = xmlDoc.CreateXmlDeclaration("1.0", "utf-8", null);
xmlDoc.AppendChild(xmlDecl);
// 创建根节点
XmlElement root = xmlDoc.CreateElement("Users");
xmlDoc.AppendChild(root);
// 创建第一个用户节点
XmlElement user1 = xmlDoc.CreateElement("User");
// 给User节点添加属性
user1.SetAttribute("Id", "1");
// 创建子节点
XmlElement name1 = xmlDoc.CreateElement("Name");
name1.InnerText = "张三";
XmlElement age1 = xmlDoc.CreateElement("Age");
age1.InnerText = "25";
// 组装节点层级
user1.AppendChild(name1);
user1.AppendChild(age1);
root.AppendChild(user1);
// 创建第二个用户节点
XmlElement user2 = xmlDoc.CreateElement("User");
user2.SetAttribute("Id", "2");
XmlElement name2 = xmlDoc.CreateElement("Name");
name2.InnerText = "李四";
XmlElement age2 = xmlDoc.CreateElement("Age");
age2.InnerText = "28";
user2.AppendChild(name2);
user2.AppendChild(age2);
root.AppendChild(user2);
// 保存XML文件到指定路径
xmlDoc.Save("Users.xml");

使用XmlDocument解析XML文件

解析XML时同样可以使用XmlDocument,通过加载文件、获取节点、读取内容三个步骤完成数据提取。

using System;
using System.Xml;

// 加载XML文件
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load("Users.xml");
// 获取根节点
XmlElement root = xmlDoc.DocumentElement;
// 获取所有User节点
XmlNodeList userNodes = root.SelectNodes("User");
// 遍历节点提取数据
foreach (XmlNode userNode in userNodes)
{
    // 读取Id属性
    string userId = userNode.Attributes["Id"].Value;
    // 读取Name子节点内容
    string userName = userNode.SelectSingleNode("Name").InnerText;
    // 读取Age子节点内容
    string userAge = userNode.SelectSingleNode("Age").InnerText;
    Console.WriteLine($"用户Id:{userId},姓名:{userName},年龄:{userAge}");
}

使用XDocument生成XML文件

XDocument是.NET后续推出的LINQ to XML API,语法更简洁,支持链式调用,代码可读性更强,是目前更推荐使用的XML操作方式。

using System.Xml.Linq;

// 构建XML文档结构
XDocument xDoc = new XDocument(
    new XDeclaration("1.0", "utf-8", null),
    new XElement("Users",
        new XElement("User",
            new XAttribute("Id", "1"),
            new XElement("Name", "张三"),
            new XElement("Age", "25")
        ),
        new XElement("User",
            new XAttribute("Id", "2"),
            new XElement("Name", "李四"),
            new XElement("Age", "28")
        )
    )
);
// 保存文件
xDoc.Save("Users_XDocument.xml");

使用XDocument解析XML文件

XDocument解析XML时可以结合LINQ查询,快速筛选和提取需要的节点数据,操作效率更高。

using System;
using System.Linq;
using System.Xml.Linq;

// 加载XML文件
XDocument xDoc = XDocument.Load("Users_XDocument.xml");
// 使用LINQ查询所有User节点
var userList = xDoc.Descendants("User")
    .Select(u => new
    {
        Id = u.Attribute("Id").Value,
        Name = u.Element("Name").Value,
        Age = u.Element("Age").Value
    })
    .ToList();
// 输出解析结果
foreach (var user in userList)
{
    Console.WriteLine($"用户Id:{user.Id},姓名:{user.Name},年龄:{user.Age}");
}

两种API的选择建议

如果项目需要兼容旧版本.NET Framework,且需要频繁修改XML节点结构,可以选择XmlDocument;如果是.NET Framework 3.5及以上版本或者.NET Core/.NET 5+项目,优先选择XDocument,其语法更简洁,搭配LINQ使用可以大幅减少代码量,提升开发效率。两种API最终生成的XML文件格式完全一致,解析时也可以互相读取对方生成的文件,不存在兼容性问题。

.NETXML生成XML解析XMLXmlDocument修改时间:2026-06-16 11:06:18

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。