帝国CMS模板大全
www.admin99.cn
www.92cms.cn 帝国CMS模板下载站!,情怀,养站,二次开发!源码需求比较大的一站式会员下载,价更省!!!

C#程序中使用LINQ to 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进行查询和操作,方便快捷。

dy(“nrwz”);

赞(0)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《C#程序中使用LINQ to XML来查询XML格式数据的实例》
文章链接:https://www.admin99.cn/7797
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
QQ站长交流群:953950264

登录

找回密码

注册