Vous pouvez utiliser L'opérateur Batch de MoreLINQ (disponible à partir de NuGet) :
foreach(IEnumerable<User> batch in users.Batch(1000))
// use batch
Si la simple utilisation de la bibliothèque n'est pas envisageable, vous pouvez réutiliser l'implémentation :
public static IEnumerable<IEnumerable<T>> Batch<T>(
this IEnumerable<T> source, int size)
{
T[] bucket = null;
var count = 0;
foreach (var item in source)
{
if (bucket == null)
bucket = new T[size];
bucket[count++] = item;
if (count != size)
continue;
yield return bucket.Select(x => x);
bucket = null;
count = 0;
}
// Return the last bucket with all remaining elements
if (bucket != null && count > 0)
{
Array.Resize(ref bucket, count);
yield return bucket.Select(x => x);
}
}
Pour des raisons de performances, vous pouvez simplement retourner le seau sans appeler Select(x => x)
. Select est optimisé pour les tableaux, mais le délégué du sélecteur serait toujours invoqué sur chaque élément. Donc, dans votre cas, il est préférable d'utiliser
yield return bucket;