Перейти к основному содержимому Перейти к дополнительному содержимому

RangeAvg Функция скрипта и диаграммы

RangeAvg() возвращает среднее значение диапазона. Для ввода в функцию может использоваться диапазон значений или выражение.

Синтаксис:  

RangeAvg(first_expr[, Expression])

Возвращаемые типы данных: numeric

Аргументы:  

Аргументы этой функции могут содержать межзаписные функции, которые в свою очередь возвращают список значений.

Аргументы
Аргумент Описание
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 для каждой записи в таблице.

Результирующая таблица
RangeIDMyRangeAvg
17
24
36
412.666
56.333
65

Пример с выражением:

RangeAvg (Above(MyField),0,3))

Возвращает скользящее среднее в диапазоне из трех значений MyField, полученных получен по текущей строке и двумя строками над ней. При указании третьего аргумента как 3 функция Above() возвращает три значения, если выше достаточно строк. Эти значения являются входными для функцииRangeAvg().

Данные, используемые в примерах:

Примечание к подсказкеОтключите сортировку MyField, чтобы убедиться, что пример работает, как ожидается.
Данные образца
MyField RangeAvg (Above(MyField,0,3)) Comments
10 10Поскольку данная строка является верхней, диапазон включает только одно значение.
2 6Над этой строкой только одна строка, поэтому диапазон: 10,2.
86.6666666667 Соответствует RangeAvg(10,2,8)
189.333333333 -
510. 333333333 -
910.6666666667 -

RangeTab:

LOAD * INLINE [

MyField

10

2

8

18

5

9

] ;

Помогла ли вам эта страница?

Если вы обнаружили какую-либо проблему на этой странице или с ее содержанием — будь то опечатка, пропущенный шаг или техническая ошибка, сообщите нам об этом!