处理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%的场景。
