繁体   English   中英

Linq独特计数

[英]Linq distinct count

我返回了一些数据,如下所示:

Model { Guid Id }

我有一个总项目的int totalCountint totalCount

我正在尝试从作为类别1返回的数据中获得不同的计数,并使总项目减去类别1中的计数成为类别2。

我有以下linq来获取类别1的非重复计数,但是如何将类别2的计数添加到IEnumerable中?

var result = data.
    GroupBy(x => x.Id).
    Select(x => new { Category = "1", Value = x.Select(v => v.Id).Distinct().Count() }).
    GroupBy(x => x.Category).
    Select(x => new Item { Category = x.Key, Value = x.Sum(y => y.Value) });

项目类有2个成员:字符串表示类别,十进制表示值。

谢谢!


编辑:所以我有以下数据IEnumerable<Model> data ,它包含以下数据:

{ Id: 1 }
{ Id: 2 }
{ Id: 2 }
{ Id: 1 }
{ Id: 3 }
{ Id: 4 }

和totalCount = 10。

我想从数据中获得Id的非重复计数,在这种情况下为4,作为类别1,totalCount-非重复项成为类别2。因此,对于结果,我将获得IEnumerable of Item使其具有以下内容:

{ Category: "1", Value: 4 }, { Category: "2", Value: 6 }

现在,我的linq语句仅返回{ Category: "1", Value: 4 } ,我不知道下一步该怎么做。

您的问题不是很清楚,但是我想这就是您想要的:

int totalCount = data.Count();
int distinctCount = data.Select(x => x.Id).Distinct().Count();
List<Item> result = new List<Item>
{
    new Item() { Category = "1", Value = distinctCount },
    new Item() { Category = "2", Value = totalCount - distinctCount },
};

您一天结束时需要两个物品,还是可以作为一次退货的一部分? 您可以这样做:

var result = data.
    GroupBy(x => x.Id).
    Select(x => new { 
       DistinctCount = x.Select(v => v.Id).Distinct().Count(),
       TotalCount = data.Count()
    });

这或类似的东西可能会起作用。

我使用数据结构来面对这种情况。

Dictionary< string, List< YOUR_TYPE >> dictionary = new Dictionary<string, List< YOUR_TYPE >> ();

我们可以从源代码获得不同的密钥。

var keys = YOUR_DATA_SOURCE.Select(item => item.YOUR_KEY_NAME ).Distinct();

就像SQL一样:“从YOUR_DATA_SOURCE中选择DISTINCT YOUR_KEY_NAME”。

foreach (var key in keys) {
    var list = new List< YOUR_TYPE > ();
    list.AddRange (dataSource.Where (x => x.YOUR_Filter_Property == YOUR_KEY_NAME ).ToList ());

    dictionary.Add (key, list);
}

然后,我们可以使用Dictionary的默认功能(例如“ ContainKey”,“ Keys”)来帮助我们。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM