自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

LINQ to XML元素概括

開(kāi)發(fā) 后端
這里介紹對(duì)于LINQ to XML元素的更新操作,關(guān)鍵就是在于查詢上面,如何有效并準(zhǔn)確的查詢到目標(biāo)元素是一個(gè)比較有挑戰(zhàn)性的問(wèn)題。

在向大家詳細(xì)介紹LINQ to XML之前,首先讓大家了解下LINQ to XML元素,然后全面介紹LINQ to XML。

對(duì)于LINQ to XML元素的更新操作,關(guān)鍵就是在于查詢上面,如何有效并準(zhǔn)確的查詢到目標(biāo)元素是一個(gè)比較有挑戰(zhàn)性的問(wèn)題,這就像SQL語(yǔ)句一樣對(duì)于同一個(gè)查詢不同的寫(xiě)法和關(guān)系連接效率就不一樣,這個(gè)讀者需要自己多加練習(xí)。在上面的代碼段中,我們?nèi)ゲ檎宜袑傩詾镻artNumber=872-AA的元素并將其更新為Hello。那么如果想操作元素值,只需將修改查詢條件為:

  1. var partNos = from item in xelem.Descendants("ProductName")  
  2. where item.Value == "Lawnmower"  

XML文檔的元素名稱更新相比較于值更新要麻煩許多。由于XML文檔結(jié)構(gòu)是一個(gè)類樹(shù)形結(jié)構(gòu),學(xué)過(guò)數(shù)據(jù)結(jié)構(gòu)的讀者知道要更新一個(gè)樹(shù)節(jié)點(diǎn)的指針,最少需要三個(gè)步驟:
A. 查找目標(biāo)樹(shù)節(jié)點(diǎn)的父節(jié)點(diǎn)
B. 將先前的節(jié)點(diǎn)的孩子轉(zhuǎn)移到新節(jié)點(diǎn)
C. 將父節(jié)點(diǎn)的子節(jié)點(diǎn)替換(如果需要還要用算法重新排序樹(shù))。

所以我們也需要用同樣的邏輯來(lái)處理XML節(jié)點(diǎn)的更新。那么相比較DOM文檔對(duì)象和LINQ to XML元素名稱更新操作,LINQ to XML的步驟要簡(jiǎn)單許多。

  1. XElement xel = XElement.Load(@"example.xml");  
  2. var itemNos = from item in xel.Descendants("Item")  
  3. select item;  
  4. int n = itemNos.Count();  
  5. for (int i=0; i<n; i++)  
  6. {  
  7. // 新創(chuàng)建節(jié)點(diǎn)  
  8. XElement nEl = new XElement("Element");  
  9. // 轉(zhuǎn)移孩子節(jié)點(diǎn)  
  10. nEl.Add(itemNos.ElementAt(0).Elements());  
  11. // 替換  
  12. itemNos.ElementAt(0).ReplaceWith(nEl);  
  13. }  
  14. Console.Write(xel);  

上面的代碼是將所有名稱為Item的元素替換成名稱為Element。細(xì)心的讀者可以看到我在for循環(huán)中獲取itemNos的孩子都使用0這個(gè)索引值,為什么呢?這是因?yàn)樵诿杜e器中如果前面的對(duì)象消失那么索引位置就會(huì)下移,那么當(dāng)我們替換一個(gè)元素后,下一個(gè)元素的索引自動(dòng)變?yōu)?,所以我們只要循環(huán)指定次數(shù)就可以遍歷所有元素來(lái)。這也是為什么不用foreach的原因。那么我們進(jìn)一步的出思考XML名稱替換這個(gè)問(wèn)題。我們會(huì)發(fā)現(xiàn)LINQ to XML的XElement類提供了4個(gè)方法用來(lái)支持該功能:ReplaceAll, ReplaceAttributes, ReplaceNodes和ReplaceWith。這四個(gè)方法除了ReplaceWith是操作本元素以為,其他的都是操作元素的孩子或是屬性內(nèi)容。這里提供的好處是如果我們想遍歷替換操作,就不必去重復(fù)的查詢目標(biāo)元素。

最后,我們討論一下如何利用LINQ to XML來(lái)刪除一個(gè)元素。對(duì)于類樹(shù)形結(jié)構(gòu)的數(shù)據(jù)來(lái)說(shuō),刪除一個(gè)元素意味著兩種情況:一、刪除本節(jié)點(diǎn)和其所有子節(jié)點(diǎn);二、只刪除本節(jié)點(diǎn)。而在刪除節(jié)點(diǎn)之前,我們需要先定位到目標(biāo)節(jié)點(diǎn),所以要先進(jìn)行查詢操作:

  1. XElement xelem = XElement.Load(@"example.xml");  
  2. var partNos = from item in xelem.Descendants("Item")  
  3. where item.Attributes("PartNumber").Single().Value == "872-AA"  
  4. select item;  
  5. partNos.Remove();  
  6. Console.Write(xelem);  

【編輯推薦】

  1. LINQ Customers類概括
  2. LINQ查詢操作全面分析
  3. LINQ to SQL的Table剖析
  4. Linq數(shù)據(jù)分組全面描述
  5. LINQ查詢基礎(chǔ)概括
責(zé)任編輯:佚名 來(lái)源: 新浪博客
相關(guān)推薦

2009-09-14 16:51:33

LINQ XML樹(shù)加載

2009-09-16 16:55:07

LINQ to XML

2009-09-16 17:33:16

LINQ TO SQL

2009-09-15 17:07:24

Linq To SQL

2009-09-15 13:59:18

LINQ to Dat

2009-09-16 10:27:35

LINQ Custom

2009-09-16 10:08:06

LINQ查詢

2009-09-18 15:15:12

LINQ to SQL

2009-09-15 16:09:12

LINQ進(jìn)行查詢

2009-09-09 15:10:35

LINQ查詢句法

2011-07-22 08:43:08

XML

2009-09-18 14:07:51

LINQ to SQL

2009-09-15 15:18:00

Linq Lambda

2009-09-14 15:37:06

LINQ映射數(shù)據(jù)庫(kù)

2009-09-17 13:54:26

LINQ to XML

2009-09-15 17:30:00

Linq Lambda

2009-01-04 16:58:48

LINQ to XMLLINQXML

2009-09-17 13:30:32

LINQ to XML

2009-09-14 15:12:40

LINQ to XML

2009-09-16 15:33:22

LINQ to XML
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)