C#程序中使用LINQ to XML来查询XML格式数据的实例

内容摘要
关于LINQ to XML

LINQ to XML 是一种启用了 LINQ 的内存 XML 编程接口,使用它,可以在 .NET Framework 编程语言中处理 XML。

它将 XML 文档置于内存中,这一点很像文档对象模
文章正文

关于LINQ to XML
LINQ to XML 是一种启用了 LINQ 的内存 XML 编程接口,使用它,可以在 .NET Framework 编程语言中处理 XML。
它将 XML 文档置于内存中,这一点很像文档对象模型 (DOM)。 您可以查询和修改 XML 文档,修改之后,可以将其另存为文件,也可以将其序列化然后通过网络发送。 但是,LINQ to XML 与 DOM 不同: 它提供一种新的对象模型,这是一种更轻量的模型,使用也更方便,这种模型利用了 VisualC# 2008 在语言方面的改进。
LINQ to XML 最重要的优势是它与 Language-Integrated Query (LINQ) 的集成。 由于实现了这一集成,因此,可以对内存 XML 文档编写查询,以检索元素和属性的集合。 LINQ to XML 的查询功能在功能上(尽管不是在语法上)与 XPath 和 XQuery 具有可比性。 Visual C# 2008 集成 LINQ 后,可提供更强的类型化功能、编译时检查和改进的调试器支持。
通过将查询结果用作 XElement 和 XAttribute 对象构造函数的参数,实现了一种功能强大的创建 XML 树的方法。 这种方法称为“函数构造”,利用这种方法,开发人员可以方便地将 XML 树从一种形状转换为另一种形状。
LINQ to XML 提供了改进的 XML 编程接口,这一点可能与 LINQ to XML 的 LINQ 功能同样重要。 通过 LINQ to XML,对 XML 编程时,您可以实现任何预期的操作,包括:

  • 从文件或流加载 XML。
  • 将 XML 序列化为文件或流。
  • 使用函数构造从头开始创建 XML。
  • 使用类似 XPath 的轴查询 XML。
  • 使用 Add、Remove、ReplaceWith 和 SetValue 等方法对内存 XML 树进行操作。
  • 使用 XSD 验证 XML 树。

使用这些功能的组合,可将 XML 树从一种形状转换为另一种形状。

实例
在前一段时间开发的护士站项目中,我是for循环XMLReader的方式遍历XML文件的。也能完成相关的需求,且函数封装好了以后,可以直接调用,也挺方便。

下面用LINQ to XML来展现。具体更详细的东西可以去查MSND。

客户端的XML文件如下,为了展现方便我只取了3项:

<?xml version="1.0"?>
<ROWSET>
 <ROW>
 <就诊序号>1</就诊序号>
 <就诊日期>2012-06-11</就诊日期>
 <病人ID>00002468</病人ID>
 <姓名>吴建平</姓名>
 <性别>男</性别>
 <年龄>42</年龄>
 <就诊科室>2981</就诊科室>
 </ROW>
 <ROW>
 <就诊序号>2</就诊序号>
 <就诊日期>2012-06-11</就诊日期>
 <病人ID>00002467</病人ID>
 <姓名>蔡蕊</姓名>
 <性别>女</性别>
 <年龄>33</年龄>
 <就诊科室>2981</就诊科室>
 </ROW>
 <ROW>
 <就诊序号>3</就诊序号>
 <就诊日期>2012-06-11</就诊日期>
 <病人ID>412905</病人ID>
 <姓名>aaa</姓名>
 <性别>男</性别>
 <年龄>24</年龄>
 <就诊科室>2981</就诊科室>
 </ROW>
</ROWSET>

怎么展现呢?关注Form1_Load方法如下:

using System;
using System.Linq;
using System.Windows.Forms;
using System.Xml.Linq;

namespace Lint2XMLDatabinding
{
 public partial class Form1 : Form
 {
  public Form1()
  {
   InitializeComponent();
  }

  private void Form1_Load(object sender, EventArgs e)
  {
   string xmlFilePath = @"./当前在科病人基本信息.xml";
   XDocument doc = XDocument.Load(xmlFilePath);

   var query = from p in doc.Descendants("ROW")//doc.Descendants("ROW")
      where p.Element("就诊序号").Value!="1"
      select new { A = p.Element("就诊序号").Value, B = p.Element("病人ID").Value, C = p.Element("姓名").Value ,D=p.Element("性别").Value };
   
   dataGridView1.DataSource= query.ToList();
   
  }
 }
}

程序结果如下:

本篇博文用来示例的Demo很简单,目的单纯为了使用LINQ。操作XML文件的方法有很多,不用LINQ当然也没什么问题。

其实,迄今为止,.NET Framework一共提供了两套处理XML数据的类库:

一、即DebugLZQ前面项目里用的的符合DOM标准的类库:宝库XmlDocument、XmlElement、XmlNode、XmlAttribute等类。这套类库的特点是中规中矩、功能强大,但也背负了太多XML的传统和复杂。

二、以LINQ为基础的类库:包括XDocument、XElement、XNode、XAttribute等类。这套类库的特点是可以使用LINQ进行查询和操作,方便快捷。


代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!