C#程序中使用LINQ to XML来查询XML格式数据的实例
2021-04-08 06:26
标签:相关 处理 姓名 ini bar list 修改 通过 发送 LINQ to XML 是一种启用了 LINQ 的内存 XML 编程接口,使用它,可以在 .NET Framework 编程语言中处理 XML。 使用这些功能的组合,可将 XML 树从一种形状转换为另一种形状。 实例 下面用LINQ to XML来展现。具体更详细的东西可以去查MSND。 客户端的XML文件如下,为了展现方便我只取了3项: 怎么展现呢?关注Form1_Load方法如下: 程序结果如下: 本篇博文用来示例的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格式数据的实例 标签:相关 处理 姓名 ini bar list 修改 通过 发送 原文地址:https://www.cnblogs.com/cnote/p/9090793.html
它将 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 编程时,您可以实现任何预期的操作,包括:
在前一段时间开发的护士站项目中,我是for循环XMLReader的方式遍历XML文件的。也能完成相关的需求,且函数封装好了以后,可以直接调用,也挺方便。
xml
version
=
"1.0"
?>
ROWSET
>
ROW
>
1就诊序号>
2012-06-11就诊日期>
00002468病人ID>
吴建平姓名>
男性别>
42年龄>
2981就诊科室>
ROW
>
ROW
>
2就诊序号>
2012-06-11就诊日期>
00002467病人ID>
蔡蕊姓名>
女性别>
33年龄>
2981就诊科室>
ROW
>
ROW
>
3就诊序号>
2012-06-11就诊日期>
412905病人ID>
aaa姓名>
男性别>
24年龄>
2981就诊科室>
ROW
>
ROWSET
>
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();
}
}
}
文章标题:C#程序中使用LINQ to XML来查询XML格式数据的实例
文章链接:http://soscw.com/index.php/essay/72749.html