LINQ to XML 是 C# 中用于创建、查询和操作 XML 文档的一组类,位于 System.Xml.Linq 命名空间中。它结合了 LINQ 的强大查询能力与简洁的 API,让处理 XML 更加直观和高效,相比传统的 DOM 模型(如 XmlDocument)更易于使用。
创建 XML 文档
使用 XDocument 和 XElement 可以轻松构建 XML 结构。
XDocument 表示整个 XML 文档,包括声明、文档类型等。 XElement 表示 XML 元素,是构建内容的主要类型。示例:创建一个简单的 XML 文档
using System;
using System.Xml.Linq;
<p>XDocument doc = new XDocument(
new XDeclaration("1.0", "utf-8", "yes"),
new XElement("Books",
new XElement("Book",
new XAttribute("Id", "1"),
new XElement("Title", "C# 入门"),
new XElement("Author", "张三")
),
new XElement("Book",
new XAttribute("Id", "2"),
new XElement("Title", "LINQ 实战"),
new XElement("Author", "李四")
)
)
);</p><p>doc.Save("books.xml");</p>加载和读取 XML 文档
可以使用 XDocument.Load 从文件或流中加载 XML,也可以用 XDocument.Parse 从字符串解析。
示例:加载并读取所有书名
XDocument doc = XDocument.Load("books.xml");
<p>var titles = from book in doc.Descendants("Book")
select (string)book.Element("Title");</p><p>foreach (string title in titles)
{
Console.WriteLine(title);
}</p>查询 XML 数据(LINQ 查询)
利用 LINQ 语法可以方便地筛选、投影和转换 XML 数据。
示例:查找作者为“张三”的书籍
var query = from book in doc.Descendants("Book")
where (string)book.Element("Author") == "张三"
select new
{
Id = (int)book.Attribute("Id"),
Title = (string)book.Element("Title")
};
<p>foreach (var item in query)
{
Console.WriteLine($"ID: {item.Id}, 标题: {item.Title}");
}</p>修改 XML 文档
可以添加、修改或删除节点和属性。
示例:添加一本新书
XElement root = doc.Root;
root.Add(
new XElement("Book",
new XAttribute("Id", "3"),
new XElement("Title", "ASP.NET 教程"),
new XElement("Author", "王五")
)
);
doc.Save("books.xml");
示例:删除某本书(比如 ID 为 2 的)
var bookToRemove = doc.Descendants("Book")
.FirstOrDefault(b => (int)b.Attribute("Id") == 2);
if (bookToRemove != null)
{
bookToRemove.Remove();
doc.Save("books.xml");
}
小贴士
使用隐式转换:XElement 支持直接转成 string、int 等类型,例如 (string)element 或 (int?)attribute(可空类型避免异常)。 注意命名空间:如果 XML 包含命名空间,查询时需使用正确的 XNamespace。 性能考虑:适合中小规模 XML 文件;超大文件建议用 XmlReader/XmlWriter。基本上就这些。LINQ to XML 让 XML 操作变得像写查询语句一样自然,代码清晰易维护。
