我正在使用一个 linq 查询,它看起来(经过一些简化)类似于以下内容:
List<UserExams> listUserExams = GetUserExams();
var examData =
from userExam in listUserExams
group by userExam.ExamID into groupExams
select new ExamData()
{
ExamID = groupExams.Key,
AverageGrade = groupExams.Average(e => e.Grade),
PassedUsersNum = groupExams.Count(e => /* Some long and complicated calculation */),
CompletionRate = 100 * groupExams.Count(e => /* The same long and complicated calculation */) / TotalUsersNum
};
困扰我的是出现两次的计算表达式,用于 PassedUsersNum 和 CompletionRate。
假设,CompletionRate = (PassedUsersNum / TotalUsersNum) * 100
我如何通过重用 PassedUsersNum 的计算来编写它,而不是再次编写该表达式?