Linq:如何按最大项目数进行分组

nam*_*los 8 c# linq grouping

CONTEXT

  • 我有一个项目列表(或任意长度).我想把它们分成一定大小的'块'
  • 示例:我有12个客户[0,1,2,3,4,5,6,7,8,9,10,11],并希望将5个组块分组,这将给出[0,1,2,3] ,4] [5,6,7,8,9] [10,11]
  • 注意:实际上我不与客户合作或单调增加整数.我选择它只是为了简化提问

我的问题

如何制定执行此分组的简单LINQ查询(使用查询语法)?

背景

  • 我已经熟悉如何使用LINQ语法按值进行分组(按客户ID分组销售),但是我不知道如何使用LINQ干净利落地优雅地表达"分块".我不确定它是否可能以直截了当的方式进行.
  • 我可以并且已经在普通的C#中实现了一个解决方案而不使用LINQ语法.因此,我的问题不是在这个问题上被阻止,而是我正在寻找方法在LINQ中表达它(再次干净和优雅)

oku*_*ane 9

您可以按(index/chunkSize)对它们进行分组.例:

    var result =
        from i in array.Select((value, index) => new { Value = value, Index = index })
        group i.Value by i.Index / chunkSize into g
        select g;
Run Code Online (Sandbox Code Playgroud)

  • 这是普通 for 循环和字典比 LINQ 更短且更易于理解的罕见情况之一...... (2认同)