gpt4 book ai didi

c# - linq 到 XML : unique attribute value count per group

转载 作者:行者123 更新时间:2023-11-30 16:54:05 24 4
gpt4 key购买 nike

我有如下的 XML 节点。

...
<ParentNode>
<Node id="2343" name="some name" mode="Some Mode">
//Some child nodes here
</Node>
<Node id="2344" name="some other name" mode="Some Mode">
//Some child nodes here
</Node>
...
</ParentNode>
<ParentNode>
<Node id="2343" name="some name" mode="Some Other Mode">
//Some child nodes here
</Node>
<Node id="2344" name="some other name" mode="Some Mode">
//Some child nodes here
</Node>
</ParentNode>
....

我需要的是

id      name             distinct-mode-count
--------------------------------------------
2343 some name 2
2344 some other name 1

我已经在下面尝试得到这个。

XElement myXML = XElement.Load(filePath);

IEnumberable<XElement> parentNodes = myXML.Descendants("ParentNode");

var nodeAttributes = parentNodes.Select(le => le.Descendants("Node")
.GroupBy(x => new {
id = x.Attribute("id").Value,
name = x.Attribute("name").Value
}).Select(g => new {
id = g.Key.id,
name = g.Key.name,
distinct_mode_count = // This is where I am stuck
}));

我不确定如何在上述查询中获取 distinct_mode_count

编辑

我需要属性 "mode" 的不同属性值计数,无论它们在哪个 ParentNode 中。

最佳答案

假设您想要计算具有相同 ID/名称的节点内不同的“模式”属性值,您只需要从组中的每个元素投影到模式,然后采用这些模式的不同序列,然后算一下:

您只需要计算组的数量,并使用 SelectMany 来“展平”您的父节点。 (或者只使用 myXml.Descendants("Node") 开始。)

给出您想要的结果的简短但完整的示例:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;

class Test
{
static void Main()
{
XElement myXML = XElement.Load("test.xml");

IEnumerable<XElement> parentNodes = myXML.Descendants("ParentNode");
var nodeAttributes = parentNodes
.SelectMany(le => le.Descendants("Node"))
.GroupBy(x => new {
Id = x.Attribute("id").Value,
Name = x.Attribute("name").Value
})
.Select(g => new {
g.Key.Id,
g.Key.Name,
DistinctModeCount = g.Select(x => x.Attribute("mode").Value)
.Distinct()
.Count()
});
foreach (var item in nodeAttributes)
{
Console.WriteLine(item);
}
}
}

或者:

XElement myXML = XElement.Load("test.xml");

var nodeAttributes = myXML
.Descendants("Node")
.GroupBy(...)
// Remaining code as before

关于c# - linq 到 XML : unique attribute value count per group,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30841856/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com