我有一个对象列表(区域),其中包含一些对象(俱乐部),我希望根据俱乐部总数将其分为四个部分。

假设我有一个x区域列表,其中包含各种数量的俱乐部。
如果俱乐部总数为40,则每组俱乐部应有大约10个俱乐部。

public class Club
{
    public string Name { get; set; }
    public int ID { get; set; }
}

public class Region
{
    public string Name { get; set; }
    public List<Club> Club { get; set; }
}

最佳答案

您可以使用分组(不保留俱乐部的顺序)

 List<IEnumerable<Club>> groups = region.Club.Select((c,i) => new {c,i})
                                             .GroupBy(x => x.i % 4)
                                             .Select(g => g.Select(x => x.c))
                                             .ToList();


MoreLINQ批次(保留俱乐部的订单):

int batchSize = region.Club.Count / 4 + 1;
var groups = region.Club.Batch(batchSize);

10-07 17:20