intenté hacer esto como lo haría en C#, con un tipo anónimo, pero el resultado es simplemente incorrecto.¿Cómo se usa GroupBy() para agrupar en varias columnas con VB.NET?
VB.NET ejemplo (salida mal):
Module Module1
Sub Main()
Dim ls As List(Of Employee) = New List(Of Employee)
ls.Add(New Employee With {.Age = 20, .Sex = "M"})
ls.Add(New Employee With {.Age = 20, .Sex = "M"})
ls.Add(New Employee With {.Age = 20, .Sex = "M"})
ls.Add(New Employee With {.Age = 30, .Sex = "F"})
ls.Add(New Employee With {.Age = 30, .Sex = "F"})
For Each item In ls.GroupBy(Function(k) New With {.Age = k.Age, .Sex = k.Sex})
Console.WriteLine(String.Format("Group [Age: {0}, Sex: {1}] : {2} Item(s)", item.Key.Age, item.Key.Sex, item.Count()))
Next
Console.ReadLine()
End Sub
Class Employee
Private _Age As Integer
Public Property Age() As Integer
Get
Return _Age
End Get
Set(ByVal value As Integer)
_Age = value
End Set
End Property
Private _Sex As String
Public Property Sex() As String
Get
Return _Sex
End Get
Set(ByVal value As String)
_Sex = value
End Set
End Property
End Class
End Module
de salida:
Group [Age: 20, Sex: M] : 1 Item(s)
Group [Age: 20, Sex: M] : 1 Item(s)
Group [Age: 20, Sex: M] : 1 Item(s)
Group [Age: 30, Sex: F] : 1 Item(s)
Group [Age: 30, Sex: F] : 1 Item(s)
salida deseada:
Group [Age: 20, Sex: M] : 3 Item(s)
Group [Age: 30, Sex: F] : 2 Item(s)
ejemplo de C# (salida correcta):
class Program
{
static void Main(string[] args)
{
List<Employee> ls = new List<Employee>();
ls.Add(new Employee { Age = 20, Sex = "M" });
ls.Add(new Employee { Age = 20, Sex = "M" });
ls.Add(new Employee { Age = 20, Sex = "M" });
ls.Add(new Employee { Age = 30, Sex = "F" });
ls.Add(new Employee { Age = 30, Sex = "F" });
foreach (var item in ls.GroupBy(k => new { Age = k.Age, Sex = k.Sex }))
{
Console.WriteLine(String.Format("Group [Age: {0}, Sex: {1}] : {2} Item(s)", item.Key.Age, item.Key.Sex, item.Count()));
}
Console.ReadLine();
}
class Employee
{
public int Age { get; set; }
public string Sex { get; set; }
}
}
¿Alguien ve dónde está mi error?