Queryable.Average 方法
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
计算数值序列的平均值。
重载
Average(IQueryable<Single>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Single 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static float Average(System::Linq::IQueryable<float> ^ source);
public static float Average (this System.Linq.IQueryable<float> source);
static member Average : System.Linq.IQueryable<single> -> single
<Extension()>
Public Function Average (source As IQueryable(Of Single)) As Single
参数
- source
- IQueryable<Single>
要计算其平均值的 Single 值序列。
返回
值序列的平均值。
例外
source
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average(IQueryable<Int32>) 计算值序列的平均值。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请将源序列的元素替换为相应数值类型的元素。
List<int> grades = new List<int> { 78, 92, 100, 37, 81 };
double average = grades.AsQueryable().Average();
Console.WriteLine("The average grade is {0}.", average);
// This code produces the following output:
//
// The average grade is 77.6.
Dim grades As New List(Of Integer)(New Integer() {78, 92, 100, 37, 81})
Dim average As Double = grades.AsQueryable().Average()
MsgBox(String.Format("The average grade is {0}.", average))
' This code produces the following output:
'
' The average grade is 77.6.
注解
方法 Average(IQueryable<Single>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Single>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Single>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average(IQueryable<Nullable<Int64>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Int64 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<double> Average(System::Linq::IQueryable<Nullable<long>> ^ source);
public static double? Average (this System.Linq.IQueryable<long?> source);
static member Average : System.Linq.IQueryable<Nullable<int64>> -> Nullable<double>
<Extension()>
Public Function Average (source As IQueryable(Of Nullable(Of Long))) As Nullable(Of Double)
参数
- source
- IQueryable<Nullable<Int64>>
要计算平均值的可以为 null 的 Int64 值序列。
返回
如果源序列为空或仅包含 null
值,则为 null
;否则为值序列的平均值。
例外
source
为 null
。
示例
下面的代码示例演示如何使用 Average(IQueryable<Nullable<Int64>>) 计算值序列的平均值。
long?[] longs = { null, 10007L, 37L, 399846234235L };
double? average = longs.AsQueryable().Average();
Console.WriteLine("The average is {0}.", average);
// This code produces the following output:
//
// The average is 133282081426.333.
Dim longs() As Nullable(Of Long) = {Nothing, 10007L, 37L, 399846234235L}
Dim average As Nullable(Of Double) = longs.AsQueryable().Average()
MsgBox(String.Format("The average is {0}.", average))
' This code produces the following output:
'
' The average is 133282081426.333.
注解
方法 Average(IQueryable<Nullable<Int64>>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Nullable<Int64>>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Nullable<Int64>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average(IQueryable<Nullable<Int32>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Int32 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<double> Average(System::Linq::IQueryable<Nullable<int>> ^ source);
public static double? Average (this System.Linq.IQueryable<int?> source);
static member Average : System.Linq.IQueryable<Nullable<int>> -> Nullable<double>
<Extension()>
Public Function Average (source As IQueryable(Of Nullable(Of Integer))) As Nullable(Of Double)
参数
- source
- IQueryable<Nullable<Int32>>
要计算平均值的可以为 null 的 Int32 值序列。
返回
如果源序列为空或仅包含 null
值,则为 null
;否则为值序列的平均值。
例外
source
为 null
。
示例
下面的代码示例演示如何使用 Average(IQueryable<Nullable<Int64>>) 计算值序列的平均值。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请将源序列的元素替换为相应数值类型的元素。
long?[] longs = { null, 10007L, 37L, 399846234235L };
double? average = longs.AsQueryable().Average();
Console.WriteLine("The average is {0}.", average);
// This code produces the following output:
//
// The average is 133282081426.333.
Dim longs() As Nullable(Of Long) = {Nothing, 10007L, 37L, 399846234235L}
Dim average As Nullable(Of Double) = longs.AsQueryable().Average()
MsgBox(String.Format("The average is {0}.", average))
' This code produces the following output:
'
' The average is 133282081426.333.
注解
方法 Average(IQueryable<Nullable<Int32>>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Nullable<Int32>>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Nullable<Int32>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average(IQueryable<Nullable<Double>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Double 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<double> Average(System::Linq::IQueryable<Nullable<double>> ^ source);
public static double? Average (this System.Linq.IQueryable<double?> source);
static member Average : System.Linq.IQueryable<Nullable<double>> -> Nullable<double>
<Extension()>
Public Function Average (source As IQueryable(Of Nullable(Of Double))) As Nullable(Of Double)
参数
- source
- IQueryable<Nullable<Double>>
要计算平均值的可以为 null 的 Double 值序列。
返回
如果源序列为空或仅包含 null
值,则为 null
;否则为值序列的平均值。
例外
source
为 null
。
示例
下面的代码示例演示如何使用 Average(IQueryable<Nullable<Int64>>) 计算值序列的平均值。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请将源序列的元素替换为相应数值类型的元素。
long?[] longs = { null, 10007L, 37L, 399846234235L };
double? average = longs.AsQueryable().Average();
Console.WriteLine("The average is {0}.", average);
// This code produces the following output:
//
// The average is 133282081426.333.
Dim longs() As Nullable(Of Long) = {Nothing, 10007L, 37L, 399846234235L}
Dim average As Nullable(Of Double) = longs.AsQueryable().Average()
MsgBox(String.Format("The average is {0}.", average))
' This code produces the following output:
'
' The average is 133282081426.333.
注解
方法 Average(IQueryable<Nullable<Double>>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Nullable<Double>>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Nullable<Double>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average(IQueryable<Nullable<Single>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Single 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<float> Average(System::Linq::IQueryable<Nullable<float>> ^ source);
public static float? Average (this System.Linq.IQueryable<float?> source);
static member Average : System.Linq.IQueryable<Nullable<single>> -> Nullable<single>
<Extension()>
Public Function Average (source As IQueryable(Of Nullable(Of Single))) As Nullable(Of Single)
参数
- source
- IQueryable<Nullable<Single>>
要计算平均值的可以为 null 的 Single 值序列。
返回
如果源序列为空或仅包含 null
值,则为 null
;否则为值序列的平均值。
例外
source
为 null
。
示例
下面的代码示例演示如何使用 Average(IQueryable<Nullable<Int64>>) 计算值序列的平均值。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请将源序列的元素替换为相应数值类型的元素。
long?[] longs = { null, 10007L, 37L, 399846234235L };
double? average = longs.AsQueryable().Average();
Console.WriteLine("The average is {0}.", average);
// This code produces the following output:
//
// The average is 133282081426.333.
Dim longs() As Nullable(Of Long) = {Nothing, 10007L, 37L, 399846234235L}
Dim average As Nullable(Of Double) = longs.AsQueryable().Average()
MsgBox(String.Format("The average is {0}.", average))
' This code produces the following output:
'
' The average is 133282081426.333.
注解
方法 Average(IQueryable<Nullable<Single>>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Nullable<Single>>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Nullable<Single>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average(IQueryable<Int64>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Int64 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static double Average(System::Linq::IQueryable<long> ^ source);
public static double Average (this System.Linq.IQueryable<long> source);
static member Average : System.Linq.IQueryable<int64> -> double
<Extension()>
Public Function Average (source As IQueryable(Of Long)) As Double
参数
- source
- IQueryable<Int64>
要计算其平均值的 Int64 值序列。
返回
值序列的平均值。
例外
source
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average(IQueryable<Int32>) 计算值序列的平均值。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请将源序列的元素替换为相应数值类型的元素。
List<int> grades = new List<int> { 78, 92, 100, 37, 81 };
double average = grades.AsQueryable().Average();
Console.WriteLine("The average grade is {0}.", average);
// This code produces the following output:
//
// The average grade is 77.6.
Dim grades As New List(Of Integer)(New Integer() {78, 92, 100, 37, 81})
Dim average As Double = grades.AsQueryable().Average()
MsgBox(String.Format("The average grade is {0}.", average))
' This code produces the following output:
'
' The average grade is 77.6.
注解
方法 Average(IQueryable<Int64>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Int64>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Int64>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average(IQueryable<Int32>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Int32 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static double Average(System::Linq::IQueryable<int> ^ source);
public static double Average (this System.Linq.IQueryable<int> source);
static member Average : System.Linq.IQueryable<int> -> double
<Extension()>
Public Function Average (source As IQueryable(Of Integer)) As Double
参数
- source
- IQueryable<Int32>
要计算其平均值的 Int32 值序列。
返回
值序列的平均值。
例外
source
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average(IQueryable<Int32>) 计算值序列的平均值。
List<int> grades = new List<int> { 78, 92, 100, 37, 81 };
double average = grades.AsQueryable().Average();
Console.WriteLine("The average grade is {0}.", average);
// This code produces the following output:
//
// The average grade is 77.6.
Dim grades As New List(Of Integer)(New Integer() {78, 92, 100, 37, 81})
Dim average As Double = grades.AsQueryable().Average()
MsgBox(String.Format("The average grade is {0}.", average))
' This code produces the following output:
'
' The average grade is 77.6.
注解
方法 Average(IQueryable<Int32>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Int32>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Int32>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average(IQueryable<Double>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Double 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static double Average(System::Linq::IQueryable<double> ^ source);
public static double Average (this System.Linq.IQueryable<double> source);
static member Average : System.Linq.IQueryable<double> -> double
<Extension()>
Public Function Average (source As IQueryable(Of Double)) As Double
参数
- source
- IQueryable<Double>
要计算其平均值的 Double 值序列。
返回
值序列的平均值。
例外
source
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average(IQueryable<Int32>) 计算值序列的平均值。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请将源序列的元素替换为相应数值类型的元素。
List<int> grades = new List<int> { 78, 92, 100, 37, 81 };
double average = grades.AsQueryable().Average();
Console.WriteLine("The average grade is {0}.", average);
// This code produces the following output:
//
// The average grade is 77.6.
Dim grades As New List(Of Integer)(New Integer() {78, 92, 100, 37, 81})
Dim average As Double = grades.AsQueryable().Average()
MsgBox(String.Format("The average grade is {0}.", average))
' This code produces the following output:
'
' The average grade is 77.6.
注解
方法 Average(IQueryable<Double>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Double>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Double>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average(IQueryable<Decimal>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Decimal 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static System::Decimal Average(System::Linq::IQueryable<System::Decimal> ^ source);
public static decimal Average (this System.Linq.IQueryable<decimal> source);
static member Average : System.Linq.IQueryable<decimal> -> decimal
<Extension()>
Public Function Average (source As IQueryable(Of Decimal)) As Decimal
参数
- source
- IQueryable<Decimal>
要计算其平均值的 Decimal 值序列。
返回
值序列的平均值。
例外
source
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average(IQueryable<Int32>) 计算值序列的平均值。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请将源序列的元素替换为相应数值类型的元素。
List<int> grades = new List<int> { 78, 92, 100, 37, 81 };
double average = grades.AsQueryable().Average();
Console.WriteLine("The average grade is {0}.", average);
// This code produces the following output:
//
// The average grade is 77.6.
Dim grades As New List(Of Integer)(New Integer() {78, 92, 100, 37, 81})
Dim average As Double = grades.AsQueryable().Average()
MsgBox(String.Format("The average grade is {0}.", average))
' This code produces the following output:
'
' The average grade is 77.6.
注解
方法 Average(IQueryable<Decimal>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Decimal>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Decimal>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average(IQueryable<Nullable<Decimal>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Decimal 值序列的平均值。
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<System::Decimal> Average(System::Linq::IQueryable<Nullable<System::Decimal>> ^ source);
public static decimal? Average (this System.Linq.IQueryable<decimal?> source);
static member Average : System.Linq.IQueryable<Nullable<decimal>> -> Nullable<decimal>
<Extension()>
Public Function Average (source As IQueryable(Of Nullable(Of Decimal))) As Nullable(Of Decimal)
参数
- source
- IQueryable<Nullable<Decimal>>
要计算平均值的可以为 null 的 Decimal 值序列。
返回
如果源序列为空或仅包含 null
值,则为 null
;否则为值序列的平均值。
例外
source
为 null
。
示例
下面的代码示例演示如何使用 Average(IQueryable<Nullable<Int64>>) 计算值序列的平均值。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请将源序列的元素替换为相应数值类型的元素。
long?[] longs = { null, 10007L, 37L, 399846234235L };
double? average = longs.AsQueryable().Average();
Console.WriteLine("The average is {0}.", average);
// This code produces the following output:
//
// The average is 133282081426.333.
Dim longs() As Nullable(Of Long) = {Nothing, 10007L, 37L, 399846234235L}
Dim average As Nullable(Of Double) = longs.AsQueryable().Average()
MsgBox(String.Format("The average is {0}.", average))
' This code produces the following output:
'
' The average is 133282081426.333.
注解
方法 Average(IQueryable<Nullable<Decimal>>) 生成一个 MethodCallExpression 表示调用 Average(IQueryable<Nullable<Decimal>>) 本身的 。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average(IQueryable<Nullable<Decimal>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是计算 中 source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Single 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static float Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, float> ^> ^ selector);
public static float Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,float>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, single>> -> single
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Single))) As Single
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
要计算其平均值的值序列。
- selector
- Expression<Func<TSource,Single>>
要应用于每个元素的投影函数。
返回
值序列的平均值。
例外
source
或 selector
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算类型的String值序列中的平均String长度。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请更改函数的 selector
主体。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型的 Expression<TDelegate> 参数,其类型参数是其中一种 Func<T,TResult> 类型。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>) 生成一个 , MethodCallExpression 表示将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>) 自身作为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在调用selector
每个值后计算中source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Single 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<float> Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<float>> ^> ^ selector);
public static float? Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,float?>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<single>>> -> Nullable<single>
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Single)))) As Nullable(Of Single)
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
要计算其平均值的值序列。
- selector
- Expression<Func<TSource,Nullable<Single>>>
要应用于每个元素的投影函数。
返回
值序列的平均值;如果 source
序列为空或仅包含 null
值,则为 null
。
例外
source
或 selector
为 null
。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算类型的String值序列中的平均String长度。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请更改函数的 selector
主体。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型的 Expression<TDelegate> 参数,其类型参数是其中一种 Func<T,TResult> 类型。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>) 生成一个 , MethodCallExpression 表示将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>) 自身作为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 参数的 IQueryProvider 由 Provider 属性表示的 source
方法。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在调用selector
每个值后计算中source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Int64 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<double> Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<long>> ^> ^ selector);
public static double? Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,long?>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<int64>>> -> Nullable<double>
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Long)))) As Nullable(Of Double)
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
要计算其平均值的值序列。
- selector
- Expression<Func<TSource,Nullable<Int64>>>
要应用于每个元素的投影函数。
返回
值序列的平均值;如果 source
序列为空或仅包含 null
值,则为 null
。
例外
source
或 selector
为 null
。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算类型的String值序列中的平均String长度。
注意
此代码示例使用方法的重载,该方法不同于本文所述的特定重载。 若要将示例扩展到本文所述的重载,请更改函数的 selector
主体。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型 Expression<TDelegate> 参数,其类型参数是类型之 Func<T,TResult> 一。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>) 生成一个 , MethodCallExpression 它将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>) 自身表示为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在对每个值调用selector
后计算 中source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Double 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<double> Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<double>> ^> ^ selector);
public static double? Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,double?>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<double>>> -> Nullable<double>
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Double)))) As Nullable(Of Double)
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
要计算其平均值的值序列。
- selector
- Expression<Func<TSource,Nullable<Double>>>
要应用于每个元素的投影函数。
返回
值序列的平均值;如果 source
序列为空或仅包含 null
值,则为 null
。
例外
source
或 selector
为 null
。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算 类型String值序列中的平均String长度。
注意
此代码示例使用 方法的重载,该方法不同于本文介绍的特定重载。 若要将示例扩展到本文介绍的重载,请更改 函数的 selector
主体。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型 Expression<TDelegate> 参数,其类型参数是类型之 Func<T,TResult> 一。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>) 生成一个 , MethodCallExpression 它将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>) 自身表示为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在对每个值调用selector
后计算 中source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Int32 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<double> Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<int>> ^> ^ selector);
public static double? Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,int?>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<int>>> -> Nullable<double>
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Integer)))) As Nullable(Of Double)
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
要计算其平均值的值序列。
- selector
- Expression<Func<TSource,Nullable<Int32>>>
要应用于每个元素的投影函数。
返回
值序列的平均值;如果 source
序列为空或仅包含 null
值,则为 null
。
例外
source
或 selector
为 null
。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算 类型String值序列中的平均String长度。
注意
此代码示例使用 方法的重载,该方法不同于本文介绍的特定重载。 若要将示例扩展到本文介绍的重载,请更改 函数的 selector
主体。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型 Expression<TDelegate> 参数,其类型参数是类型之 Func<T,TResult> 一。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>) 生成一个 , MethodCallExpression 它将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>) 自身表示为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 参数的 IQueryProvider 由 属性表示Provider的 source
的 方法。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在对每个值调用selector
后计算 中source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Int64 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static double Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, long> ^> ^ selector);
public static double Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,long>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, int64>> -> double
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Long))) As Double
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
要计算其平均值的值序列。
- selector
- Expression<Func<TSource,Int64>>
要应用于每个元素的投影函数。
返回
值序列的平均值。
例外
source
或 selector
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算 类型String值序列中的平均String长度。
注意
此代码示例使用 方法的重载,该方法不同于本文介绍的特定重载。 若要将示例扩展到本文介绍的重载,请更改 函数的 selector
主体。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型 Expression<TDelegate> 参数,其类型参数是类型之 Func<T,TResult> 一。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>) 生成一个 , MethodCallExpression 它将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>) 自身表示为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在对每个值调用selector
后计算 中source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Int32 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static double Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, int> ^> ^ selector);
public static double Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,int>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, int>> -> double
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Integer))) As Double
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
要计算其平均值的值序列。
- selector
- Expression<Func<TSource,Int32>>
要应用于每个元素的投影函数。
返回
值序列的平均值。
例外
source
或 selector
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算 类型String值序列中的平均String长度。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型 Expression<TDelegate> 参数,其类型参数是类型之 Func<T,TResult> 一。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 生成一个 , MethodCallExpression 它将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 自身表示为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在对每个值调用selector
后计算 中source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Double 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static double Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, double> ^> ^ selector);
public static double Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,double>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, double>> -> double
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Double))) As Double
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
要计算其平均值的值序列。
- selector
- Expression<Func<TSource,Double>>
要应用于每个元素的投影函数。
返回
值序列的平均值。
例外
source
或 selector
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算 类型String值序列中的平均String长度。
注意
此代码示例使用 方法的重载,该方法不同于本文介绍的特定重载。 若要将示例扩展到本文介绍的重载,请更改 函数的 selector
主体。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型 Expression<TDelegate> 参数,其类型参数是类型之 Func<T,TResult> 一。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) 生成一个 , MethodCallExpression 它将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) 自身表示为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在对每个值调用selector
后计算 中source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算 Decimal 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Decimal Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, System::Decimal> ^> ^ selector);
public static decimal Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,decimal>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, decimal>> -> decimal
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Decimal))) As Decimal
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
用于计算平均值的值序列。
- selector
- Expression<Func<TSource,Decimal>>
要应用于每个元素的投影函数。
返回
值序列的平均值。
例外
source
或 selector
为 null
。
source
中不包含任何元素。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算 类型String值序列中的平均String长度。
注意
此代码示例使用 方法的重载,该方法不同于本文介绍的特定重载。 若要将示例扩展到本文介绍的重载,请更改 函数的 selector
主体。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型 Expression<TDelegate> 参数,其类型参数是类型之 Func<T,TResult> 一。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>) 生成一个 , MethodCallExpression 它将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>) 自身表示为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在对每个值调用selector
后计算 中source
值的平均值。
适用于
Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
计算可以为 null 的 Decimal 值序列的平均值,该序列是通过对输入序列中的每个元素调用投影函数而获得的。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<System::Decimal> Average(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<System::Decimal>> ^> ^ selector);
public static decimal? Average<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,decimal?>> selector);
static member Average : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<decimal>>> -> Nullable<decimal>
<Extension()>
Public Function Average(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Decimal)))) As Nullable(Of Decimal)
类型参数
- TSource
source
的元素类型。
参数
- source
- IQueryable<TSource>
要计算其平均值的值序列。
- selector
- Expression<Func<TSource,Nullable<Decimal>>>
要应用于每个元素的投影函数。
返回
值序列的平均值;如果 source
序列为空或仅包含 null
值,则为 null
。
例外
source
或 selector
为 null
。
示例
下面的代码示例演示如何使用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 计算 类型String值序列中的平均String长度。
注意
此代码示例使用 方法的重载,该方法不同于本文介绍的特定重载。 若要将示例扩展到本文介绍的重载,请更改 函数的 selector
主体。
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };
// Determine the average string length in the array.
double average = fruits.AsQueryable().Average(s => s.Length);
Console.WriteLine("The average string length is {0}.", average);
// This code produces the following output:
//
// The average string length is 6.5.
Dim fruits() As String = {"apple", "banana", "mango", "orange", "passionfruit", "grape"}
' Determine the average string length in the array.
Dim average As Double = fruits.AsQueryable().Average(Function(s) s.Length)
MsgBox(String.Format("The average string length is {0}.", average))
' This code produces the following output:
'
' The average string length is 6.5.
注解
此方法至少有一个类型 Expression<TDelegate> 参数,其类型参数是类型之 Func<T,TResult> 一。 对于这些参数,可以传入 lambda 表达式,它将编译为 Expression<TDelegate>。
方法 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>) 生成一个 , MethodCallExpression 它将调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>) 自身表示为构造的泛型方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将 传递给 由 Provider 参数的 属性表示的 的 source
方法IQueryProvider。
由于执行表示调用 Average<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>) 的表达式树而发生的查询行为取决于参数类型的 source
实现。 预期行为是在对每个值调用selector
后计算 中source
值的平均值。