[英]How to group XML data using LINQ in C#.net?
我想使用C#.net讀取xml文件,並借助LINQ我想根據INSTANCE和CINSTANCE值對xml中的節點進行分組。 我怎樣才能做到這一點? 這是我的源模式:
<XYZ>
<TYPE>A</TYPE>
<INSTANCE>1357599</INSTANCE>
<CHILD>DESCRIPTION</CHILD>
<CINSTANCE>PQR</CINSTANCE>
<CPOS>0000</CPOS>
</XYZ>
<XYZ>
<TYPE>GP</TYPE>
<INSTANCE>1472422</INSTANCE>
<CHILD>A</CHILD>
<CINSTANCE>1357599</CINSTANCE>
<CPOS>0010</CPOS>
</XYZ>
<XYZ>
<TYPE>GP</TYPE>
<INSTANCE>1472427</INSTANCE>
<CHILD>A</CHILD>
<CINSTANCE>1357599</CINSTANCE>
<CPOS>0010</CPOS>
</XYZ>
<XYZ>
<TYPE>A</TYPE>
<INSTANCE>1357600</INSTANCE>
<CHILD>DESCRIPTION</CHILD>
<CINSTANCE>PQR</CINSTANCE>
<CPOS>0000</CPOS>
</XYZ>
<XYZ>
<TYPE>GP</TYPE>
<INSTANCE>1472425</INSTANCE>
<CHILD>A</CHILD>
<CINSTANCE>1357600</CINSTANCE>
<CPOS>0010</CPOS>
</XYZ>
<XYZ>
<TYPE>GP</TYPE>
<INSTANCE>1472426</INSTANCE>
<CHILD>A</CHILD>
<CINSTANCE>1357600</CINSTANCE>
<CPOS>0010</CPOS>
</XYZ>
這應該是我的輸出:
<Group>
<XYZ>
<TYPE>A</TYPE>
<INSTANCE>1357599</INSTANCE>
<CHILD>DESCRIPTION</CHILD>
<CINSTANCE>PQR</CINSTANCE>
<CPOS>0000</CPOS>
</XYZ>
<XYZ>
<TYPE>GP</TYPE>
<INSTANCE>1472422</INSTANCE>
<CHILD>A</CHILD>
<CINSTANCE>1357599</CINSTANCE>
<CPOS>0010</CPOS>
</XYZ>
<XYZ>
<TYPE>GP</TYPE>
<INSTANCE>1472427</INSTANCE>
<CHILD>A</CHILD>
<CINSTANCE>1357599</CINSTANCE>
<CPOS>0010</CPOS>
</XYZ>
</Group>
<Group>
<XYZ>
<TYPE>A</TYPE>
<INSTANCE>1357600</INSTANCE>
<CHILD>DESCRIPTION</CHILD>
<CINSTANCE>PQR</CINSTANCE>
<CPOS>0000</CPOS>
</XYZ>
<XYZ>
<TYPE>GP</TYPE>
<INSTANCE>1472425</INSTANCE>
<CHILD>A</CHILD>
<CINSTANCE>1357600</CINSTANCE>
<CPOS>0010</CPOS>
</XYZ>
<XYZ>
<TYPE>GP</TYPE>
<INSTANCE>1472426</INSTANCE>
<CHILD>A</CHILD>
<CINSTANCE>1357600</CINSTANCE>
<CPOS>0010</CPOS>
</XYZ>
</Group>
我需要根據INSTANCE==CINSTANCE
對XYZ節點進行INSTANCE==CINSTANCE
。.是否為此編寫了邏輯?
您可能正在尋找類似以下代碼的內容,但是您的格式需要做一些細微的更改,它需要Xml中的有效父元素。
static void Main(string[] args)
{
string xml = @"<ELEMENTS><XYZ> <TYPE>A</TYPE> <INSTANCE>1357599</INSTANCE> <CHILD>DESCRIPTION</CHILD> <CINSTANCE>PQR</CINSTANCE> <CPOS>0000</CPOS> </XYZ> <XYZ> <TYPE>GP</TYPE> <INSTANCE>1472422</INSTANCE> <CHILD>A</CHILD> <CINSTANCE>1357599</CINSTANCE> <CPOS>0010</CPOS> </XYZ> <XYZ> <TYPE>GP</TYPE> <INSTANCE>1472427</INSTANCE> <CHILD>A</CHILD> <CINSTANCE>1357599</CINSTANCE> <CPOS>0010</CPOS> </XYZ> <XYZ> <TYPE>A</TYPE> <INSTANCE>1357600</INSTANCE> <CHILD>DESCRIPTION</CHILD> <CINSTANCE>PQR</CINSTANCE> <CPOS>0000</CPOS> </XYZ> <XYZ> <TYPE>GP</TYPE> <INSTANCE>1472425</INSTANCE> <CHILD>A</CHILD> <CINSTANCE>1357600</CINSTANCE> <CPOS>0010</CPOS> </XYZ> <XYZ> <TYPE>GP</TYPE> <INSTANCE>1472426</INSTANCE> <CHILD>A</CHILD> <CINSTANCE>1357600</CINSTANCE> <CPOS>0010</CPOS> </XYZ></ELEMENTS>";
Console.WriteLine(GetGroups(xml).ToString());
}
private static XDocument GetGroups(string xml)
{
XDocument xyzElementsDocument = XDocument.Parse(xml);
var results = from xyzElement1 in xyzElementsDocument.Descendants("XYZ")
join xyzElement2 in xyzElementsDocument.Descendants("XYZ")
on (string)xyzElement1.Element("INSTANCE") equals (string)xyzElement2.Element("CINSTANCE") into joinedElements
from joinedElement in joinedElements.DefaultIfEmpty()
group xyzElement1 by joinedElement != null into groupedElements
select new { HasCInstance = groupedElements.Key, Elements = groupedElements.Distinct() };
XDocument groupDocument = new XDocument();
groupDocument.Add(new XElement("GROUPS"));
foreach (var result in results)
{
XElement groupElement = new XElement("GROUP");
groupElement.Add(result.Elements);
groupDocument.Root.Add(groupElement);
}
return groupDocument;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.