欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# LINQ to XML應用介紹

 更新時間:2012年11月21日 10:55:57   作者:  
.Net又引入了LINQ,于是LINQ to XML也就應運而生,所以在.Net中,不僅可以用W3C XML DOM標準,還可以使用LINQ to XML來操作XML文檔。下面就來簡單介紹一下如何使用LINQ to XML
W3C制定了XML DOM標準,.Net為了支持W3C的標準,從1.1版本開始就引入了XmlDocument類。我在前一篇博客中,介紹了如何使用XmlDocument類來對XML文檔進行操作。后來 .Net又引入了LINQ,于是LINQ to XML也就應運而生,所以在.Net中,不僅可以用W3C XML DOM標準,還可以使用LINQ to XML來操作XML文檔。下面就來簡單介紹一下如何使用LINQ to XML。
(一) 加載
加載XML比較常用的有三種方法:
復制代碼 代碼如下:

public static XDocument Load(string uri);
public static XDocument Load(Stream stream);
public static XDocument Parse(string text);

下面代碼演示如何使用它們:
復制代碼 代碼如下:

// public static XDocument Load(string uri);
// uri 即為要裝載的文件名
var doc1 = XDocument.Load("XMLFile1.xml");
// public static XDocument Load(Stream stream);
Entity retrievedAnnotation = _orgService.Retrieve("annotation"
, new Guid("C1B13C7F-F430-E211-8FA1-984BE1731399"), new ColumnSet(true));
byte[] fileContent = Convert.FromBase64String(retrievedAnnotation["documentbody"].ToString());
MemoryStream ms = new MemoryStream(fileContent);
XDocument xDoc = XDocument.Load(ms);
// public static XDocument Parse(string text);
string str = @"<Customers><Customer id='01' city='Beijing' country='China' name='Lenovo'/></Customers>";
var doc2 = XDocument.Parse(str);

(二) 查詢
我們以下面的XML文檔為例:
復制代碼 代碼如下:

<?xml version="1.0" encoding="utf-8" ?>
<Customers>
<Customer id="01" city="Beijing" country="China">Lenovo
<Order OrderID="1001" Freight="36.00" />
<Order OrderID="1003" Freight="61.50" />
</Customer>
<Customer id="02" city="Amsterdam" country="The Netherlands">Shell
<Order OrderID="1002" Freight="56.65" />
<Order OrderID="1004" Freight="65.50" />
<Order OrderID="1005" Freight="100.50" />
</Customer>
</Customers>

1. 返回所有Customer 節(jié)點:
復制代碼 代碼如下:

var result = from customer in doc1.Descendants("Customer")
select customer.Value;
foreach (var s in result)
{
Console.WriteLine(s);
}

輸出結果:
Lenovo
Shell
2. 返回id為02并且 city 為 Amsterdam 的customer :
復制代碼 代碼如下:

var result = (from customer in doc1.Descendants("Customer")
where (string)customer.Attribute("id") == "02" && (string)customer.Attribute("city") == "Amsterdam"
select customer.Value).FirstOrDefault();
Console.WriteLine(result);

輸出結果:
Shell
3. 查找出 order ID 1003的customer ID和它的freight:
復制代碼 代碼如下:

var result = (from order in doc1.Descendants("Order")
where order.Attribute("OrderID").Value == "1003"
select new
{
CustomerID = order.Parent.Attribute("id").Value,
Freight = (decimal)order.Attribute("Freight")
}).FirstOrDefault();
Console.WriteLine(string.Format("Customer ID: {0} Freight: {1}", result.CustomerID, result.Freight));

輸出結果:
Customer ID: 01 Freight: 61.50
4. 查詢每個客戶的freight的總和
復制代碼 代碼如下:

var result = from customer in doc1.Descendants("Customer")
select new
{
CustomerName = customer.Value,
TotalFreight = customer.Descendants("Order").Sum(o => (decimal)o.Attribute("Freight"))
};
foreach (var r in result)
{
Console.WriteLine(string.Format("Customer: {0} Total Freight: {1}", r.CustomerName, r.TotalFreight));
}

輸出結果:
Customer: Lenovo Total Freight: 97.50
Customer: Shell Total Freight: 222.65
5. 使用LINQ to XML Join
Join可以用在LINQ to XML和其他的LINQ providers,比如說LINQ to Objects。下面的代碼展示了如何將一個數(shù)組和一個XML文件Join起來。
復制代碼 代碼如下:

string[] orders = {"1001", "2000", "1002"};
var result = from order in doc1.Descendants("Order")
join selected in orders
on (string)order.Attribute("OrderID") equals selected
select new
{
CustomerName = order.Parent.Value,
OrderID = selected,
Freight = (decimal)(order.Attribute("Freight"))
};
foreach (var r in result)
{
Console.WriteLine(string.Format("Customer ID: {0} Order:{1} Freight: {2}", r.CustomerName, r.OrderID, r.Freight));
}

輸出結果:
Customer ID: Lenovo Order:1001 Freight: 36,00
Customer ID: Shell Order:1002 Freight: 56,65
(三) 創(chuàng)建
以創(chuàng)建以下XML文檔為例:
復制代碼 代碼如下:

<?xml version="1.0" encoding="utf-8"?>
<Customers>
<Customer id="01" city="Beijing" country="China" name="Lenovo">
<Order OrderID="1001" Freight="36.00" />
</Customer>
</Customers>

復制代碼 代碼如下:

var doc = new XDocument(
new XElement("Customers",
new XElement("Customer",
new XAttribute("id", "01"),
new XAttribute("city", "Beijing"),
new XAttribute("country", "China"),
new XAttribute("name", "Lenovo"),
new XElement("Order",
new XAttribute("OrderID", "1001"),
new XAttribute("Freight", "36.00")
)
)
)
);
doc.Save("test.xml");

總結:
1. XDocument提供了對XML文檔在內存中的隨機的讀寫操作。
2. XDocument使用LINQ to XML來讀取XML結點。
3. 你可以通過LINQ投射(projection)來將XML變換為Object。
4. LINQ投射可以將XML變換為IEnumerable<String>。
5. LINQ投射可以將XML變換為其他格式的XML。

相關文章

  • C#使用NPOI導出Excel類封裝

    C#使用NPOI導出Excel類封裝

    這篇文章主要為大家詳細介紹了C#使用NPOI導出Excel類封裝,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 基于WPF實現(xiàn)簡單的下拉篩選控件

    基于WPF實現(xiàn)簡單的下拉篩選控件

    這篇文章主要為大家詳細介紹了如何基于WPF實現(xiàn)簡單的下拉篩選控件,文中的示例代碼講解詳細,對我們學習或工作有一定幫助,感興趣的小伙伴可以了解一下
    2023-04-04
  • C#如何對多線程、多任務管理(demo)

    C#如何對多線程、多任務管理(demo)

    這篇文章主要通過一個小demo介紹了C#如何對多線程、多任務管理,需要的朋友可以參考下
    2015-07-07
  • C# null 合并運算符??(雙問號)使用示例

    C# null 合并運算符??(雙問號)使用示例

    這篇文章主要介紹了C# null 合并運算符??(雙問號)使用示例,?? 運算符稱作 null 合并運算符。如果此運算符的左操作數(shù)不為 null,則此運算符將返回左操作數(shù);否則返回右操作數(shù),需要的朋友可以參考下
    2014-06-06
  • C#手動操作DataGridView使用各種數(shù)據(jù)源填充表格實例

    C#手動操作DataGridView使用各種數(shù)據(jù)源填充表格實例

    本文主要介紹了C#手動操作DataGridView使用各種數(shù)據(jù)源填充表格實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02
  • 基于WPF實現(xiàn)視頻封面查看器

    基于WPF實現(xiàn)視頻封面查看器

    這篇文章主要為大家詳細介紹了WPF如何實現(xiàn)視頻封面查看器,文中的示例代碼講解詳細,對我們學習或工作有一定幫助,感興趣的小伙伴可以了解一下
    2022-11-11
  • C#后端接收form-data,創(chuàng)建實體類教程

    C#后端接收form-data,創(chuàng)建實體類教程

    這篇文章主要介紹了C#后端接收form-data,創(chuàng)建實體類教程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 實例代碼講解c# 線程(上)

    實例代碼講解c# 線程(上)

    這篇文章主要介紹了講解c# 線程的的相關資料,文中示例代碼非常詳細,供大家參考和學習,感興趣的朋友可以了解下
    2020-06-06
  • C#實現(xiàn)繪制隨機噪點和直線

    C#實現(xiàn)繪制隨機噪點和直線

    這篇文章主要為大家詳細介紹了C#如何實現(xiàn)繪制隨機噪點和直線,文中的示例代碼講解詳細,對我們學習C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-01-01
  • C#中DataTable 轉換為 Json的方法匯總(三種方法)

    C#中DataTable 轉換為 Json的方法匯總(三種方法)

    JavaScript Object Notation (Json)是一種輕量級的數(shù)據(jù)交換格式,下面小編給大家介紹三種方法實現(xiàn)DataTable轉換成 Json 對象,感興趣的朋友一起看看吧
    2016-11-11

最新評論