3

我是使用 lambda 表达式的初学者。

我有一个经销商列表,我必须计算每个经销商的等级。

要求是将等级计算分离到一个单独的方法中。

所以我正在编写以下两种方法,但是我无法将参数传递给CalculateGrade()方法,

public IEnumerable<Dealers> GetDealerGrades(IEnumerable<Dealers> gradeData)
{
    return gradeData
        .GroupBy(row => new { row.Name })
        .Select(g => new Dealers
        {
            Name = g.Key.Name,
            TotalPoints = CalculateGrade(x => Convert.ToDouble(x.RecievedPoints),
                                         y => y.MaxPoints,
                                         z => Convert.ToDouble(z.Weightage)) 
        })
        .ToList();
}

private double CalculateGrade(double d1, int d2, double d3)
{
    return ( d1 / d2 ) 
        * d3 == 0.00 ? 1
        : d3;
}

有人可以建议如何在 this 中传递参数,或者如何传递 lamda 表达式并计算等级?

提前谢谢了...

4

2 回答 2

5

看起来你需要这样:

return gradeData
    .GroupBy(row => row.Name)
    .Select(g => new Dealers
    {
        Name = g.Key.Name,
        TotalPoints = g.Sum(x => CalculateGrade(Convert.ToDouble(x.RecievedPoints),
                                                x.MaxPoints,
                                                Convert.ToDouble(x.Weightage)))
    })
    .ToList();

它将调用CalculateGrade组中每个元素的方法,并将返回值汇总到TotalPoints属性中。

或者你可以改变你CalculateGrade的采取IEnumerabale<Dealers>

private double CalculateGrade(IEnumerable<Dealers> dealers)
{
    // calculations here
    return dealers.Sum(x => CalculateGrade(Convert.ToDouble(x.RecievedPoints),
                                            x.MaxPoints,
                                            Convert.ToDouble(x.Weightage)))
}

并在您的查询中使用它:

return gradeData
    .GroupBy(row => row.Name)
    .Select(g => new Dealers
    {
        Name = g.Key.Name,
        TotalPoints = CalculateGrade(g)
    })
    .ToList();
于 2013-09-12T10:02:11.783 回答
3

这并不能解决您的问题,但它为您提供了如何将 lambdas 发送到方法中的概述

您将使用 Func & Action 将 lambdas 传递给方法

功能

可以有 1 - 15 个输入参数,并且必须有一个输出参数

行动

可以有 1 - 16 个输入参数,没有输出参数

即,我如何想象他们在 EntityFramework 中为 where 谓词执行此操作

public static List<People> Filter<TEntity>(this List<People> myList, Func<TEntity, TResult> predicate)
{
    return myList.Where(predicate).ToList();
}

用法将类似于

myList.Filter(ml => ml.Age > 18);
于 2013-09-12T10:12:46.970 回答