任何人都知道如何设置一个平均值的默认值?我有这样一条线
dbPlugins = (from p in dbPlugins select new { Plugin = p,Avgscore = p.DbVersions.Average(x => x.DbRatings.Average(y => y.score)) }) .OrderByDescending(x => x.Avgscore) .Select(x => x.Plugin).ToList();
这引起了一个错误,因为我还没有评级.如果我没有我想要的平均值默认为0.我认为这应该是一个扩展方法,我可以指定默认值应该是什么.
解决方法
有:
DefaultIfEmpty
.
我不知道你的DbVersions和DbRatings是什么,哪个集合完全有零个项目,但这是一个想法:
var emptyCollection = new List<int>(); var average = emptyCollection.DefaultIfEmpty(0).Average();
更新:(重复以下意见中的内容以提高可见度)
如果您发现自己需要在类类型的集合上使用DefaultIfEmpty,请记住,您可以在聚合之前将LINQ查询更改为项目.例如:
class Item { public int Value { get; set; } } var list = new List<Item>(); var avg = list.Average(item => item.Value);
如果您不想/不能构造一个值等于0的默认项,则可以首先投影到一个int集合,然后提供一个默认值:
var avg = list.Select(item => item.Value).DefaultIfEmpty(0).Average();