使用LINQ to XML来查询XML
用于XML的语言集成查询(LINQ to XML)允许使用标准查询操作符就像树形操作符一样来查询XML数据,它能够提供类似XPath的导航在后代、祖先和兄弟的XML元素中导航。它简化了对XML数据的使用,不必使用额外的语言语法像XPath或XQuery。你可以使用LINQ to XML对你从文件系统、从一个远程web service或从一个内存中的XML内容中获得的XML执行LINQ查询。这篇文章将只关注于使用LINQ从一个XML文件——Customers.xml文件查询XML。
创建一个简单的LINQ项目
我们将命名我们的Visual Studio项目为ConsoleLINQtoXML,并使用C#语言。使用using 指令添加下面的命名空间。System.Xml.Linq命名空间包含LINQ to XML所用到的类。
using System.Xml; //namespace to deal with XML documents
using System.Xml.Linq; //namespace to deal with LINQ to XML classes
接下来,我们将在我们的项目中添加Customers.xml文件。你也可以选择将这个XML文件存储在你的文件系统中的一个目录下,但是为了简单起见,我们将只把它包含进我们的项目。在Visual Studio中点击Project菜单并选择Add Existing Item...。
选择Customers.xml文件并点击Add。这个XML文件将被添加到你的项目中。
从Solutions Explorer右键单击文件Customers.xml并选择Properties。这将显示Properties窗口。
在Customers.xml文件的Properties窗口中,点击Copy to Output Directory选项并从下拉列表框中选择Copy always。
现在我们开始编写LINQ查询来读取我们的XML文件。首先在static void Main(string[] args)中编写一些代码。
// Create the query var custs = from c in XElement.Load("Customers.xml").Elements("Customers") select c ; // Execute the query foreach (var customer in custs) { Console.WriteLine(customer); } //Pause the application Console.ReadLine(); |
你将注意到它是使用XElement类来显示XML元素。XElement类的Load方法很简单地将Customers.xml文件加载到XElement类中去。Elements方法返回XML文档中这个元素——Customers元素——的一个过滤的子元素集合。这只是显示了LINQ是多么强大,因为你对集合使用相同的语言查询构造而现在是对XML文档。你甚至可以执行排序、过滤和分组如同你平常在LINQ中所做的。你可以插入一个where条件从句到上面的查询中来过滤你的结果。
where c.Element("Country").Value == "Italy" |
当你在Visual Studio中运行你的项目时,你的输出将看起来如下所示。你可以点击F5或点击Visual Studio中的Debug - Start Debugging来运行。
不使用LINQ来做相同的事情是要复杂得多,因为你仍然需要在节点间搜索以访问这些元素和它们的值。