Linq学习<五> 运用linq查询Xml
这节将学习如何用 linq查询xml
一、我们先看看在xml中我们怎么操作
public void xmlWayToQueryXmlFile()
{
XmlDocument xmldoc = new XmlDocument();
xmldoc.Load("../../xmlFile.xml"); XmlNode root = xmldoc.DocumentElement;
XmlNode node = root.SelectSingleNode("custom[id='100']");
Console.Write(node.InnerText);
}
这是在using system.xml条件下查询xml中id=100的node下所有的innerText
关于在xml中查询方法,这里讲的比较详细http://www.cnblogs.com/fjsnail/archive/2012/10/20/2732127.html
二、我们看看用linq又怎么操作
函数一: Elements()返回XML文档或片段中的所有第一级元素。对于有效的XML文档,例如,刚才创
建的NorthwindCustomerOrders.xml文件,只有一个第一级元素,即根元素customers
public void queryXml()
{
string filePath = "../../xmlFile.xml";
XDocument xdoc = XDocument.Load(filePath); var result = from item in xdoc.Elements()
select item.Name; foreach(var i in result)
{
Console.WriteLine(i);
} }
当时如果把select item.Name 改为select.value 则显示的是所有innerText,如果改为select item ,那么显示是所有xml文档
函数二:Descendants()返回XML文档或片段中的所有子元素(所有级别的子元素)
public void queryXmlByDescendants()
{
string filePath = "../../xmlFile.xml"; <custom>
XDocument xdoc = XDocument.Load(filePath); <id>1</id>
<name>gougou</name>
var result = from item in xdoc.Descendants() <age>23</age>
// select item.Value; //显示所有子元素的值 </custom>
select item.Name; //显示所有子元素的标签
foreach (var i in result)
{
Console.WriteLine(i);
} }
注意:select item.Value时,如果xml像上面右侧那样 显示的结果是1gougou23 1 gougou 23 (应该是先显示custom级的value,把下面的子节点value全部显示出来,再循环到下面的子节点,显示单个子节点的value)
当然可以加distict 除掉重复的值
foreach (var i in result.Distinct())
{
Console.WriteLine(i);
}
这样就可以显示所有id的值
var result = from item in xdoc.Descendants("id")
select item.Value; //显示所有子元素的值
函数三 Attributes(),它返回当前选中元素的所有特性
对于行如这样的xml
<custom sequence="1" boolChange="false">
<id>0</id>
<name>nihao</name>
<age>112</age>
</custom>
public void queryXmlByAttributes()
{
string filePath = "../../xmlFile.xml";
XDocument xdoc = XDocument.Load(filePath); var result = from item in xdoc.Descendants("custom").Attributes()
select item; //显示所有子元素的值 foreach (var i in result)
{
Console.WriteLine(i);
} }
上面代码显示的是:sequence="1"boolChange="false"
如果把 select item改为select item.name 则输出:sequence boolchange
如果该为select item.value 则输出1 false
总结:xml的操作方法有多种,不仅可以用xml 本身提供的api,还可以用linq to xml ,各有各的好处,相比二样linq更方便
在使用之前,记得要添加:
using System.Linq;
using System.Xml.Linq
using System.Xml;
Linq学习<五> 运用linq查询Xml的更多相关文章
- [LINQ2Dapper]最完整Dapper To Linq框架(五)---查看Linq实际执行的SQL
此例子是使用LINQ2Dapper封装,效率优于EntityFramwork,并且支持.NetFramework和.NetCore框架,只依赖于Dapper支持.net framework4.6.1及 ...
- Linq学习之旅——LINQ查询表达式
1. 概述 2. from子句 3. where子句 4. select子句 5. group子句 6. into子句 7. 排序子句 8. let子句 9. join子句 10. 小结 1. 概述 ...
- Linq学习(一)-初涉Linq
一.何谓LINQ LINQ:Language Integrated Query语言集成查询,其本质是对ADO.NET结果集通过反射连同泛型特性转换成对象集,实现OR模型的转换 二.优点与缺点 优点:封 ...
- LINQ学习系列-----3.1 查询非泛型集合
一.问题起源 LINQ to object在设计时,是配合IEnumerable<T>接口的泛型集合类型使用的,例如字典.数组.List<T>等,但是对于继承了IEnumera ...
- LINQ学习系列-----3.1 查询非泛型集合和多个分组
一.查询非泛型集合 1.问题起源 LINQ to object在设计时,是配合IEnumerable<T>接口的泛型集合类型使用的,例如字典.数组.List<T>等,但是对于继 ...
- Linq学习(五)-多表连接
本将主要介绍 内连接与 外连接 1.join Linq to sql from a in Blog_Users join b in Blog_UserInfo on a.UserId equals b ...
- Oracle 数据库基础学习 (五) 多表查询
多表查询:查询结果需要用到两个或者以上表,此时需要多表连接,产生多表查询 1.内连接(等值连接) 示例:将两个表内容连接显示 select * from dept d, emp e where d.d ...
- Linq学习<四> linq to XML
LINQ to XML并不打算替代标准的XML API,例如,XML DOM(Document Object Model).Path.XQuery和XSLT等.如果熟悉这些API或当前需要使用或学习它 ...
- LINQ to XML LINQ学习第一篇
LINQ to XML LINQ学习第一篇 1.LINQ to XML类 以下的代码演示了如何使用LINQ to XML来快速创建一个xml: public static void CreateDoc ...
随机推荐
- python学习(二十三) String(下) 分片和索引
分片: 记住, 是开闭区间. a = "abcdef"print(a[:])print(a[1:])print(a[:3])print(a[-2])print(a[:-2])pri ...
- ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var mysql (转)
ps -A | grep -i mysql kill 列出来的进程 service mysql start 我的问题就解决了 ------------------------------------- ...
- Oracle 热备份
Oracle 热备份是指数据库处于open状态下,对数据库的数据文件.控制文件.参数文件.密码文件等进行一系列备份操作. 热备是基于用户管理备份恢复的一种方式,也是除了RMAN备份之外较为常用的一种备 ...
- 4_python之路之模拟工资管理系统
python之路之模拟工资管理系统 1.程序说明:Readme.txt 1.程序文件:salary_management.py info.txt 2.程序文件说明:salary_management. ...
- Python Object Oriented
1. Creating class class className: 'Optional class documentation string' class_suite The class has a ...
- jquery 实现点击图片居住放大缩小
该功能是基于jquery实现的,所以 第一步则是引入jquery jquery下载地址:https://jquery.com/download/ 或者使用此时调试的版本(3版本) /*! jQuery ...
- OpenLayers 3 之 地图视图(View)
OpenLayers 3 之 地图视图(View) 初始化一幅地图,必备的三要素之一视图(view),这个对象主要是控制地图与人的交互,如进行缩放,调节分辨率.地图的旋转等控制.也就是说每个 map对 ...
- dbf 命令 及数据类型
left()函数只能截取左边几位字符,截取中间字符用SUBSTR() SUBSTR(cExpression, nStartPosition [, nCharactersReturned]) dbf u ...
- QT与HALCON(入门)
#include "qtdesign.h" #include <QtGui/QApplication> #include "halconcpp.h" ...
- sql中问号是干什么的??
第一次在后台 程序中遇到sql语句中的问号: /** * * 方法描述 : 通过账号id更新该账号状态 * @param state 状态 * @param id 账号id */ @Modifying ...