2011-06-01 47 views
1

我有下面的XML,其被存儲在字符串類型變量加載之前卸下從使用C#存儲在字符串型變量中的XML完整節點,我使用.NET 2.0:在的XMLDocument

<?xml version="1.0"?> 
<tcm:ListPublications xmlns:tcm="http://www.tridion.com/ContentManager/5.0" Managed="1"> 
    <tcm:Item ID="tcm:0-437-1" Title="05 Main Australia Web Site (English)"/> 
    <tcm:Item ID="tcm:0-445-1" Title="06 Internal India Web Site (English)"/> 
    <tcm:Item ID="tcm:0-437-1" Title="07 EKTA Australia Web Site (English)"/> 
    <tcm:Item ID="tcm:0-445-1" Title="07 EKTA India Web Site (English)"/> 
    <tcm:Item ID="tcm:0-414-1" Title="07 Bahrain web Site (Arabic)"/> 
    <tcm:Item ID="tcm:0-272-1" Title="07 USA web Site (US English)"/> 
    <tcm:Item ID="tcm:0-279-1" Title="08 Bahrain web Site (English)"/> 
    <tcm:Item ID="tcm:0-392-1" Title="08 Belgium web Site (French)"/> 
    <tcm:Item ID="tcm:0-321-1" Title="08 Brazil web Site (English)"/> 
</tcm:ListPublications> 

現在,在將它加載到XMLDocument之前,我只想加載標題中標題爲「07」且不包含「EKTA」的那些「Item」節點。

和C#代碼來做到這一點下面給出:

//Creating the object of PublicatinBL class. 
PublicationBL pubBL = new PublicationBL(); 

//All publications list XML. 
//Here I am getting the whole XML as shown above. 
string pubListXML = pubBL.getAllPublicationListXML(); 

XmlDocument xDocument = new XmlDocument(); 

//Loading the publication list XML. 
//Here before loading the XML, I want to modify it as required above. 
xDocument.LoadXml(pubListXML); 
+1

這有什麼錯去除'xDocument'節點?要移除節點,無論如何您都必須以這種或那種方式加載XML。使用像'// tcm:Item [contains(@ title,'07')] [!contains(@ title,'EKTA')]''這樣的xpath來選擇目標是很容易的。 – 2011-06-01 05:49:25

+0

您也可以在字符串上運行正則表達式來替換與空字符串不匹配的字符串。 – cristobalito 2011-06-01 05:52:40

+0

嗨安東,我的完整的XML是在字符串變量,請你讓我知道如何使用它的XPath。 – 2011-06-01 06:57:14

回答

2

你可以使用LINQ to XML

var xdocument = XDocument.Parse(xml); 

var nodes = xdocument.Descendants(XName.Get("Item", "http://www.tridion.com/ContentManager/5.0")) 
    .Where(arg => arg.Attribute("Title").Value.Contains("07") && !arg.Attribute("Title").Value.Contains("EKTA")) 
    .ToList(); 

或者使用LINQ語法:

var nodes = (
    from node in xdocument.Descendants(XName.Get("Item", "http://www.tridion.com/ContentManager/5.0")) 
    let titleAttribute = node.Attribute("Title").Value 
    where titleAttribute.Contains("07") && !titleAttribute.Contains("EKTA") 
    select node) 
    .ToList(); 

[更新]在問題中指定了.NET 2之後。

在.NET 2您可以使用XPath:

XmlNamespaceManager xmlnsManager = new XmlNamespaceManager(xmlDocument.NameTable); 
xmlnsManager.AddNamespace("tcm", "http://www.tridion.com/ContentManager/5.0"); 
XmlNodeList nodes = xmlDocument.SelectNodes(
    "//tcm:ListPublications//tcm:Item[contains(@Title,'07') and not(contains(@Title,'EKTA'))]", 
    xmlnsManager); 
+0

THanks @Alex,但我使用的.NET 2.0沒有「VAR」和「LINQ」,請建議! – 2011-06-01 06:44:27