客户端的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的传统和复杂。











