Search code examples
linqpartitioningskiptake

LINQ Partition List into Lists of 8 members


How would one take a List (using LINQ) and break it into a List of Lists partitioning the original list on every 8th entry?

I imagine something like this would involve Skip and/or Take, but I'm still pretty new to LINQ.

Edit: Using C# / .Net 3.5

Edit2: This question is phrased differently than the other "duplicate" question. Although the problems are similar, the answers in this question are superior: Both the "accepted" answer is very solid (with the yield statement) as well as Jon Skeet's suggestion to use MoreLinq (which is not recommended in the "other" question.) Sometimes duplicates are good in that they force a re-examination of a problem.


Solution

  • Use the following extension method to break the input into subsets

    public static class IEnumerableExtensions
    {
        public static IEnumerable<List<T>> InSetsOf<T>(this IEnumerable<T> source, int max)
        {
            List<T> toReturn = new List<T>(max);
            foreach(var item in source)
            {
                    toReturn.Add(item);
                    if (toReturn.Count == max)
                    {
                            yield return toReturn;
                            toReturn = new List<T>(max);
                    }
            }
            if (toReturn.Any())
            {
                    yield return toReturn;
            }
        }
    }