RangeSum — скрипт и функция диаграммы

RangeSum() возвращает сумму диапазона значений. Все нечисловые значения приравниваются к 0 в отличие от оператора +.

Syntax:  

RangeSum(first_expr[, Expression])

Return data type: число

Arguments:  

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

Аргумент Описание
first_expr Выражение или поле, содержащее данные для суммирования.
Expression Дополнительные выражения или поля, содержащие данные для суммирования. Можно использовать несколько дополнительных выражений.

Limitations:  

Функция RangeSumсчитает все нечисловые значения равными 0, в отличие от оператора +.

Examples and results:  

Примеры Результаты
RangeSum (1,2,4)

Возвращает 7

RangeSum (5,'abc') Возвращает 5
RangeSum (null( ))

Возвращает 0

Добавьте образец скрипта в свой документ и запустите. Затем добавьте на лист документа как минимум поля, указанные в столбце с результатами, чтобы увидеть результаты.

RangeTab3:

LOAD recno() as RangeID, Rangesum(Field1,Field2,Field3) as MyRangeSum INLINE [

Field1, Field2, Field3

10,5,6

2,3,7

8,2,8

18,11,9

5,5,9

9,4,2

];

Результирующая таблица показывает возвращенные значения функции MyRangeSum для каждой записи в таблице.
RangeID MyRangeSum
1 21
2 12
3 18
4 38
5 19
6 15

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

RangeSum (Above(MyField,0,3))

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

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

Подсказка: Отключите сортировку поля MyField, чтобы убедиться, что пример работает, как ожидается.
MyField RangeSum(Above(MyField,0,3))
10 10

2

12
8 20
18 28
5 31
9 32

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

RangeTab:

LOAD * INLINE [

MyField

10

2

8

18

5

9

] ;