RangeAvg - 脚本和图表函数
RangeAvg() 用于返回范围的平均值。可以将一系列值或表达式导入该函数。
语法:
RangeAvg(first_expr[, Expression])
返回数据类型: 数字
参数:
该函数的参数可能包含内部记录函数,并在其内部返回一系列值。
参数 | 说明 |
---|---|
first_expr | 表达式或字段包含要度量的数据。 |
Expression | 可选表达式或字段包含要度量的数据范围。 |
限制:
如果找不到任何数值,则返回 NULL 值。
示例和结果:
示例 | 结果 |
---|---|
RangeAvg (1,2,4) |
返回 2.33333333 |
RangeAvg (1,'xyz') | 返回 1 |
RangeAvg (null( ), 'abc') | 返回 NULL |
示例:
将示例脚本添加到应用程序并运行。要查看结果,将结果列中列出的字段添加到应用程序中的工作表。
RangeTab3:
LOAD recno() as RangeID, RangeAvg(Field1,Field2,Field3) as MyRangeAvg INLINE [
Field1, Field2, Field3
10,5,6
2,3,7
8,2,8
18,11,9
5,5,9
9,4,2
];
结果列表显示了为表格中的每条记录返回的 MyRangeAvg 值。
RangeID | MyRangeAvg |
---|---|
1 | 7 |
2 | 4 |
3 | 6 |
4 | 12.666 |
5 | 6.333 |
6 | 5 |
带有表达式的示例:
RangeAvg (Above(MyField),0,3))
返回当前行与当前行上两行中计算的三个 MyField 值范围结果的滑动平均值。通过指定第三个参数作为 3,Above() 函数会返回三个值,如果上方有足够的行,会将其作为 RangeAvg() 函数的输入。
示例中所使用的数据:
提示注释禁用 MyField 排序可确保示例符合预期。
MyField | RangeAvg (Above(MyField,0,3)) | Comments |
---|---|---|
10 | 10 | 因为这是顶行,该范围仅包含一个值。 |
2 | 6 | 此行上方只有一行,因此范围为:10,2. |
8 | 6.6666666667 | 等于 RangeAvg(10,2,8) |
18 | 9.333333333 | - |
5 | 10. 333333333 | - |
9 | 10.6666666667 | - |
RangeTab:
LOAD * INLINE [
MyField
10
2
8
18
5
9
] ;