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

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

概述关于LINQtoXMLLINQtoXML是一种启用了LINQ的内存XML编程接口,使用它,可以在.NETFramework编程语言中处理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进行查询和 *** 作,方便快捷。

总结

以上是内存溢出为你收集整理的C#程序中使用LINQ to XML来查询XML格式数据的实例全部内容,希望文章能够帮你解决C#程序中使用LINQ to XML来查询XML格式数据的实例所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1260717.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)

保存