一行代码解决C# XML解析问题? 那些你不知道的LINQ to XML技巧

来源:这里教程网 时间:2026-02-21 17:31:48 作者:

处理XML在C#中曾是个繁琐任务,尤其用传统的

XmlDocument
XmlReader
时,代码冗长还容易出错。但自从LINQ to XML出现后,一切变得简洁高效。你真的只需要一行代码就能完成大多数XML解析需求。

用XDocument.Load + LINQ 一行提取数据

LINQ to XML 的核心是

XDocument
XLinq
查询语法。比如有如下XML:

<Books>
  <Book ID="1">
    <Title>C# in Depth</Title>
    <Author>Jon Skeet</Author>
  </Book>
  <Book ID="2">
    <Title>CLR via C#</Title>
    <Author>Jeffrey Richter</Author>
  </Book>
</Books>

你想提取所有书名,传统方式要循环节点,而现在只需一行:

var titles = XDocument.Load("books.xml").Descendants("Book").Select(b => b.Element("Title")?.Value);

这行代码加载XML、查找所有Book节点,并提取Title文本,简洁又安全(使用了null条件操作符)。

按属性筛选?Where 随手就来

想获取ID为2的作者?继续链式调用即可:

string author = XDocument.Load("books.xml") .Descendants("Book") .Where(b => (string)b.Attribute("ID") == "2") .Select(b => b.Element("Author")?.Value) .FirstOrDefault();

这里甚至不需要显式转换,LINQ to XML 支持将

XAttribute
隐式转成
string
int
等,写起来像原生类型一样自然。

构建XML也是一行的事

LINQ to XML 不只是读,写同样优雅。创建上面的XML结构可以这样:

var doc = new XDocument( new XElement("Books", from b in bookList select new XElement("Book", new XAttribute("ID", b.ID), new XElement("Title", b.Title), new XElement("Author", b.Author) ) ) );

结合LINQ查询表达式,对象转XML清晰直观,还能直接保存:

doc.Save("output.xml");

处理命名空间?一个声明搞定

带命名空间的XML常让人头疼,但只要定义

XNamespace
变量,照样简洁:

var ns = "http://example.com/books"; var titles = XDocument.Load("books.xml") .Descendants(ns + "Book") .Select(b => b.Element(ns + "Title")?.Value);

通过字符串拼接

XName
,命名空间不再干扰你的查询逻辑。

基本上就这些。LINQ to XML 把XML操作变成了类似数据库查询的体验,语法流畅,错误少,维护性强。与其写一堆遍历代码,不如掌握这几招,一行解决90%的场景。

相关推荐