在C#的XML处理场景中,XDocument是LINQ to XML的核心类,它提供了简洁的API来操作XML数据,其中Parse方法可以直接将XML格式的字符串转换为可操作的XDocument对象,不需要先读取文件或流,非常适合处理内存中的XML字符串数据。

XDocument.Parse基础用法
使用XDocument.Parse加载XML字符串非常简单,只需要传入符合XML格式的字符串即可,方法会自动解析字符串内容并返回对应的XDocument实例。下面是一个最基础的示例,演示如何加载一个简单的XML字符串并输出根节点名称。
using System;
using System.Xml.Linq;
class Program
{
static void Main()
{
// 定义符合XML格式的字符串
string xmlString = @"<?xml version=""1.0"" encoding=""utf-8""?>
<User>
<Id>1001</Id>
<Name>张三</Name>
<Age>25</Age>
</User>";
try
{
// 使用Parse方法加载XML字符串
XDocument doc = XDocument.Parse(xmlString);
// 获取根节点名称
Console.WriteLine("根节点名称:" + doc.Root.Name);
}
catch (Exception ex)
{
Console.WriteLine("解析失败:" + ex.Message);
}
}
}
读取XML节点和属性数据
加载完成XML字符串后,可以通过XDocument提供的API读取具体的节点内容和属性值,常用的操作包括获取根节点、子节点、元素值、属性值等。
读取子节点内容
可以通过Element方法获取指定名称的子节点,再通过Value属性获取节点的文本内容。
using System;
using System.Xml.Linq;
class Program
{
static void Main()
{
string xmlString = @"<User>
<Id>1001</Id>
<Name>张三</Name>
<Age>25</Age>
</User>";
XDocument doc = XDocument.Parse(xmlString);
// 获取根节点下的子节点内容
string id = doc.Root.Element("Id").Value;
string name = doc.Root.Element("Name").Value;
string age = doc.Root.Element("Age").Value;
Console.WriteLine($"用户ID:{id},姓名:{name},年龄:{age}");
}
}
读取节点属性
如果XML节点包含属性,可以通过Attribute方法获取指定名称的属性,再通过Value属性获取属性值。
using System;
using System.Xml.Linq;
class Program
{
static void Main()
{
string xmlString = @"<User id=""1001"" status=""active"">
<Name>张三</Name>
</User>";
XDocument doc = XDocument.Parse(xmlString);
// 获取根节点的属性值
string userId = doc.Root.Attribute("id").Value;
string status = doc.Root.Attribute("status").Value;
Console.WriteLine($"用户ID:{userId},状态:{status}");
}
}
处理包含命名空间的XML字符串
如果XML字符串中带有命名空间,需要在解析时指定命名空间,否则会无法匹配到对应的节点。可以通过XNamespace定义命名空间,再拼接节点名称进行查询。
using System;
using System.Xml.Linq;
class Program
{
static void Main()
{
string xmlString = @"<User xmlns=""http://ipipp.com/user"">
<Name>张三</Name>
</User>";
XDocument doc = XDocument.Parse(xmlString);
// 定义命名空间
XNamespace ns = "http://ipipp.com/user";
// 拼接命名空间和节点名称查询
string name = doc.Root.Element(ns + "Name").Value;
Console.WriteLine("用户姓名:" + name);
}
}
异常处理注意事项
使用XDocument.Parse时需要注意,如果传入的字符串不符合XML格式,会抛出XmlException异常,因此建议在解析时添加异常处理逻辑,避免程序崩溃。常见的不符合格式的情况包括标签未闭合、特殊字符未转义、编码声明错误等。
using System;
using System.Xml;
using System.Xml.Linq;
class Program
{
static void Main()
{
string invalidXml = "<User><Name>张三</User>"; // 标签未闭合的错误XML
try
{
XDocument doc = XDocument.Parse(invalidXml);
}
catch (XmlException ex)
{
Console.WriteLine("XML格式错误:" + ex.Message);
}
catch (Exception ex)
{
Console.WriteLine("其他错误:" + ex.Message);
}
}
}
常见问题说明
- XDocument.Parse和XDocument.Load的区别:Parse接收字符串参数,Load接收文件路径、流或者TextReader参数,处理字符串数据优先使用Parse。
- 如果XML字符串包含BOM头或者特殊编码,建议先确认字符串的编码格式,避免解析出现乱码。
- 解析大体积的XML字符串时,XDocument会将全部内容加载到内存,若数据量过大可以考虑使用XmlReader进行流式解析。