LINQ系列:LINQ to XML查询
2017-07-30 15:14
309 查看
1. 读取XML文件
XDocument和XElement类都提供了导入XML文件的Load()方法,可以读取XML文件的内容,并转换为XDocument或XElement类的实例。
示例XML文件:Product.xml
2. 查询根元素
3. 查询节点
4. 查询子孙节点
Descendants轴方法与Elements类型,不过Elements只查找当前元素下的直接子节点,而Descendants则会遍历当前元素下任意层级的子元素。
示例xml文件:
使用Descendants()方法查询:
5. 查询属性
示例xml文件:
XDocument和XElement类都提供了导入XML文件的Load()方法,可以读取XML文件的内容,并转换为XDocument或XElement类的实例。
示例XML文件:Product.xml
<?xml version="1.0" encoding="utf-8"?> <Products> <Product> <ProductID>1</ProductID> <ProductName>LINQ to XML</ProductName> <UnitPrice>10</UnitPrice> </Product> <Product> <ProductID>2</ProductID> <ProductName>LINQ to SQL</ProductName> <UnitPrice>20</UnitPrice> </Product> </Products>
XElement root = XElement.Load(Server.MapPath("Product.xml"));
2. 查询根元素
XDocument doc = XDocument.Load(Server.MapPath("Product.xml")); IEnumerable<XElement> elements = from e in doc.Elements("Products") select e; foreach (XElement e in elements) { Console.WriteLine("{0}-{1}", e.Name, e.Value); }
XDocument doc = XDocument.Load(Environment.CurrentDirectory + @"\Product.xml"); IEnumerable<XElement> elements = from e in doc.Elements("Products") select e; foreach (XElement e in elements) { Console.WriteLine("{0}-{1}", e.Name, e.Value); }
3. 查询节点
XDocument doc = XDocument.Load(Environment.CurrentDirectory + @"\" + "Product.xml"); var query = from p in doc.Element("Products").Elements("Product") where (int)p.Element("ProductID") == 1 select p; query.ToList().ForEach(item => { Console.WriteLine("{0}-{1}-{2}", item.Element("ProductID").Value, item.Element("ProductName").Value, item.Element("UnitPrice").Value); });
XElement xml = XElement.Load(Environment.CurrentDirectory + @"\" + "Product.xml"); var query = from p in xml.Elements("Product") where (int)p.Element("ProductID") == 1 select p;
4. 查询子孙节点
Descendants轴方法与Elements类型,不过Elements只查找当前元素下的直接子节点,而Descendants则会遍历当前元素下任意层级的子元素。
示例xml文件:
<?xml version="1.0" encoding="utf-8"?> <Products> <Product> <Book> <ProductID>1</ProductID> <ProductName>LINQ to XML</ProductName> <UnitPrice>10</UnitPrice> </Book> </Product> <Product> <Book> <ProductID>2</ProductID> <ProductName>LINQ to SQL</ProductName> <UnitPrice>20</UnitPrice> </Book> </Product> </Products>
使用Descendants()方法查询:
XElement root = XElement.Load(Environment.CurrentDirectory + @"\" + "Product.xml"); var query = from b in root.Descendants("Book") select b; foreach (var item in query) { Console.WriteLine(item.Element("ProductName").Value); }
5. 查询属性
示例xml文件:
<?xml version="1.0" encoding="utf-8"?> <Products> <Product ID="1"> <ProductID>1</ProductID> <ProductName>LINQ to XML</ProductName> <UnitPrice>10</UnitPrice> </Product> <Product ID="2"> <ProductID>2</ProductID> <ProductName>LINQ to SQL</ProductName> <UnitPrice>20</UnitPrice> </Product> </Products>
XElement xml = XElement.Load(Environment.CurrentDirectory + @"\" + "Product.xml"); var query = from p in xml.Elements("Product") where (int)p.Attribute("ID") == 1 select p;
XElement xml = XElement.Load(Environment.CurrentDirectory + @"\" + "Product.xml"); var query = from p in xml.Elements("Product") where (int)p.Attribute("ID") == 1 select new { ID = p.Attribute("ID").Value, ProductID = p.Element("ProductID").Value, ProductName = p.Element("ProductName").Value };
XElement xml = XElement.Load(Environment.CurrentDirectory + @"\" + "Product.xml"); var query = from p in xml.Nodes().OfType<XElement>() where (int)p.Attribute("ID") == 1 select new { ID = p.Attribute("ID").Value, ProductID = p.Element("ProductID").Value, ProductName = p.Element("ProductName").Value };
相关文章推荐
- linq to sql取出随机记录/多表查询/将查询出的结果生成xml
- linq to xml (linq查询)
- LINQ to XML 用 LINQ 查询 XML
- 用Linq to XML的方式查询XML 文档
- LINQ To XML:之复杂的查询举例
- linq to sql取出随机记录/多表查询/将查询出的结果生成xml
- LinQ To XML——用LinQ查询XML
- LINQ to XML 用 LINQ 查询 XML
- 用Linq to XML的方式查询XML 文档
- 用Linq to XML的方式查询XML 文档
- LINQ TO XML(查询)
- Linq to Sql 学习系列之四 查询句法
- [新手入门]快速学习 ADO.NET Entity Framework系列文章 #3 -- LINQ-to-SQL、EntitySQL、查询产生器方法(Query builder)三种语法
- LINQ to XML 用 LINQ 查询 XML
- XmlDocument和LINQ to XML两种方式对xml的创建、查询
- linq to xml 的多表查询
- Linq To Xml实现类似XPath查询(Silverlight下的XPath)
- Linq To XML:在结点下查询某一类型结点
- LINQ to SQL系列 查询 使用LINQ to SQL做简单查询
- [代码]使用LINQ的查询结果填充XML树(LINQ to XML)