[英]How to remove similar consecutive nodes from XML using c#?
XML,
<A>
<B id = "1">
<R>
<C id="ABC" />
</B>
<B id = "2" >
<R>
<C id="ABC" />
</B>
<B id = "3" >
<R>
<C id="XYZ" />
</B>
<B id = "4">
<R>
<C id="XYZ" />
</B>
<B id = "5">
<R>
<C id="QWE" />
</B>
</A>
我需要在其父<B>
節點下刪除相似的連續<C>
,並且輸出應類似於
<A>
<B id = "1">
<R>
<C id="ABC" />
</B>
<B id = "2">
<R>
</B>
<B id = "3">
<R>
<C id="XYZ" />
</B>
<B id = "4">
<R>
</B>
<B id = "5">
<R>
<C id="QWE" />
</B>
</A>
如果只能通過務實或使用linq-to-xml來實現,則不會使用。
任何幫助表示贊賞:)
可能有一種更優雅的方法來執行此操作,但這是一種簡單的方法:通過遍歷所有B
元素並跟蹤先前的C
元素。 該示例是您所擁有的內容與稍微靈活一些的設計之間的混合體,如果您在A
下要跟蹤A
以上的元素,則可以使用字典。 如果確實像您的示例一樣簡單,則擺脫字典,而只需使用XElement previousC
。
//to get this to work in Linq to XML, need to terminate the R nodes
var xml = XDocument.Parse(@"<A>
<B id = ""1"">
<R/>
<C id=""ABC"" />
</B>
<B id = ""2"" >
<R/>
<C id=""ABC"" />
</B>
<B id = ""3"" >
<R/>
<C id=""XYZ"" />
</B>
<B id = ""4"">
<R/>
<C id=""XYZ"" />
</B>
<B id = ""5"">
<R/>
<C id=""QWE"" />
</B>
</A>");
Dictionary<string, XElement> previousCElements = new Dictionary<string, XElement>();
XElement currentC, previousC;
foreach(var node in xml.Descendants("B"))
{
if (!previousCElements.ContainsKey(node.Name.LocalName))
{
previousCElements[node.Name.LocalName] = node.Element("C");
}
else
{
previousC = previousCElements[node.Name.LocalName];
currentC = node.Element("C");
if (previousC.Attribute("id").Value.Equals(currentC.Attribute("id").Value, StringComparison.InvariantCultureIgnoreCase))
{
currentC.Remove();
}
previousCElements.Remove(node.Name.LocalName);
}
}
產生的XML:
<A>
<B id="1">
<R />
<C id="ABC" />
</B>
<B id="2">
<R />
</B>
<B id="3">
<R />
<C id="XYZ" />
</B>
<B id="4">
<R />
</B>
<B id="5">
<R />
<C id="QWE" />
</B>
</A>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.