使用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所用到的类。

 

//Include the LINQ to XML namespaces
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...。

 
图1

选择Customers.xml文件并点击Add。这个XML文件将被添加到你的项目中。

 
图2

从Solutions Explorer右键单击文件Customers.xml并选择Properties。这将显示Properties窗口。

 
图3

在Customers.xml文件的Properties窗口中,点击Copy to Output Directory选项并从下拉列表框中选择Copy always。

 
图4

现在我们开始编写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来运行。

 
图5

不使用LINQ来做相同的事情是要复杂得多,因为你仍然需要在节点间搜索以访问这些元素和它们的值。

posted @ 2009-04-20 22:36  J.z  阅读(6424)  评论(5编辑  收藏  举报