I have an object allStudents = Dictionary<ClassRoom, List<Student>>()
In Linq how would I get a list of all the students who are male? (student.Gender=="m") from all the Classrooms?
Ian
I have an object allStudents = Dictionary<ClassRoom, List<Student>>()
In Linq how would I get a list of all the students who are male? (student.Gender=="m") from all the Classrooms?
Ian
Try the following
var maleStudents = allStudents
.SelectMany(x => x.Values)
.Where(x => x.Gender=="m");
The trick to this is the SelectMany
operation. It has the effect of flattening a collection of List<Student>
into a single collection of Student
. The resulting list is the same as if you'd lined up each list front to back.
You can use nested from
clause. The first from
selects all classes together with their students (an item from the dictionary), which is represented as a KeyValuePair<ClassRoom, List<Student>>
. Then you can select all students from the class using the Value
property and filter them:
var q = from cls in allStudents
from s in cls.Value
where s.Gender == "M" select s;
Under the cover, the nested from
clause is translated to the SelectMany
method call.