c# - Linq Groupby 返回原始对象

标签 c# linq group-by

我需要一些帮助来过滤一些数据。我有一个具有三个属性的对象类。我得到的对象集合可以与第一个属性 Point3d 有很多匹配项。从该匹配集合中,我需要查看第二个属性是否具有唯一值 Tag。最后,我需要能够识别 Point3d 匹配且标签不同的对象,使用第三个属性,它是 Id(它始终是唯一的)。

class pmatch
{
    public string Point3d { get; set; }
    public string Tag { get; set; }
    public string Id { get; set; }
}

我正在寻找的一个例子是:

List<pmatch> dataset = new List<pmatch>
{
    new pmatch { Point3d = "1, 1, 1", Tag = "5", Id = "123" },
    new pmatch { Point3d = "1, 1, 1", Tag = "6", Id = "124" },
    new pmatch { Point3d = "1, 1, 2", Tag = "7", Id = "125" },
    new pmatch { Point3d = "1, 1, 2", Tag = "7", Id = "126" }
};

我需要能够识别 ID 的 123 和 124,因为它们的 Point3ds 匹配,但它们的标签不匹配。我已经能够使用 LINQ 识别这些实例:

var result = datalist.GroupBy(item => item.Point3d, item => item.Tag);
foreach (var group in result)
{
    Console.WriteLine(group.Key);
    var uniqueTags = group.Distinct().ToList();
    if (uniqueTags.Count > 1)
    {
        Console.WriteLine("Found mismatched tags");
        foreach (string Tag in group)
        {
            Console.WriteLine("  {0}", Tag);
        }
    }
}

但是这些结果没有给我 ID,所以我无法访问我已经识别的对象。我如何获得这些结果以及 Id 或 pmatch 对象本身?

最佳答案

你可以像这样完成想要的结果:

var resultSet = 
       dataset.GroupBy(item => item.Point3d)
              .Where(group => group.Select(item => item.Tag)
                                   .Distinct()
                                   .Count() > 1)
              .ToDictionary(item => item.Key, item => item.ToList());

这将识别 Id 的 123124 ,因为他们的 Point3ds 匹配,但他们的标签不匹配,而且 resultSet类型为 Dictionary<string, List<pmatch>>所以你可以访问 pmatch 的所有属性对象。

关于c# - Linq Groupby 返回原始对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49614026/

相关文章:

c# - 如何获取 UTF-16 字节数组?

c# - WP7 子弹出窗口中的后退按键处理

c# - XNA 中的触摸按钮(具有按下、释放、移动状态)

python - Pandas 系列的部分总和

c# - 使用 selenium C# 查找和替换文本文件中的数据

c# - 用于在列表中选择 'previous' 值的嵌套 LINQ 查询

c# - 使用 Expression.<Factory method> 语法动态构建表达式树

c# - double[] 集合到字符串

r - 使用 dplyr 到 group_by 并按组有条件地改变数据帧

mysql - 检索每组中的最后一条记录 - MySQL