zoukankan      html  css  js  c++  java
  • LINQ to XML查询

    LINQ to XML是一个比较大的主题,在这篇博文中,DebugLZQ不想也没有必要依次讲述譬如用Linq to XML 创建删除...XML文件,lz想讲述的是在实际应用中linq to SQL 如何展现我们需要的数据,即XML文件获取以后如何进行查询想要的项目,展现在UI上。

    在前一段时间开发的护士站项目中,我是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进行查询和操作,方便快捷。

     后记:今天在园子里遇到两位大神,深感博客园里虽是鱼龙混杂,但是水也很深!他们开发的平台比较新,我辈需要更加努力!!

  • 相关阅读:
    java 学习之JVM深入分析(一)
    选择排序算法实现十个1100的随机数的排序
    spring基础知识概述
    mybatis 总结一
    ACM之java判断回文数
    Spring mvc框架
    C#实现窗体最小化到状态栏,双击运行时又能正常显示窗体
    Android调用相机并将照片存储到SD卡上实现方法
    c#中如何让一个窗体在另一个旁边
    C#实现获取时间
  • 原文地址:https://www.cnblogs.com/DebugLZQ/p/2782630.html
Copyright © 2011-2022 走看看