Above - 차트 함수

Above()는 테이블의 열 세그먼트 내의 현재 행 위에 있는 행의 표현식을 평가합니다. 계산되는 행은 offset(있는 경우) 값에 따라 달라지며 기본적으로는 바로 위에 있는 행입니다. 테이블 이외의 차트인 경우, Above()는 해당 차트의 일반표 해당 부분의 현재 행 위에 있는 행을 평가합니다.

Syntax:  

Above([TOTAL] expr [ , offset [,count]])

Return data type: dual

Arguments:  

인수 설명
expr 측정할 데이터가 포함된 표현식 또는 필드입니다.
offset

offset n을 0보다 크게 지정하면 표현식의 평가가 현재 행보다 n 행 위로 이동됩니다.

오프셋을 0으로 지정하면 현재 행의 표현식이 평가됩니다.

오프셋을 음수로 지정하면 Above 함수가 상응하는 양수 오프셋이 있는 Below 함수와 동일하게 작동합니다.

count

세 번째 인수 count를 1보다 크게 지정하면 함수에서 count 값의 범위를 반환하며, 원래 셀에서 위쪽으로 계산하여 count 테이블 행 각각에 대해 하나의 값이 반환됩니다.

이러한 형식으로 이 함수를 특별 범위 함수의 인수로 활용할 수 있습니다. 범위 함수

TOTAL

테이블이 1차원이거나 TOTAL 한정자를 인수로 사용하는 경우 현재 열 세그먼트는 항상 전체 열과 동등합니다.

집계 범위 정의

열 세그먼트의 첫 번째 행은 위에 다른 행이 없으므로 NULL 값이 반환됩니다.

참고: 열 세그먼트는 현재 정렬 순서에서 차원에 대해 동일한 값을 갖는 셀의 연속된 하위 집합으로 정의됩니다. 인터 레코드 차트 함수는 동등한 일반표 차트의 가장 오른쪽 차원을 제외한 열 세그먼트에서 계산됩니다. 차트에 차원이 하나만 있는 경우 또는 TOTAL 한정자가 지정된 경우는 표현식이 전체 테이블을 평가합니다.
참고: 테이블 또는 테이블과 동등한 것에 여러 세로 차원이 있을 경우 현재 열 세그먼트에는 필드 간 정렬 순서에서 마지막 차원이 표시되는 열을 제외하고 모든 차원 열 내의 현재 행과 같은 값을 가진 행만 포함됩니다.

Limitations:  

재귀 호출은 NULL을 반환합니다.

Examples and results:  

Example 1:  

예 1의 테이블 시각화.

이 예에서 보여주는 테이블의 스크린샷에서, 테이블 시각화는 차원 Customer와 측정값 Sum(Sales)Above(Sum(Sales))로부터 생성됩니다.

Above(Sum(Sales))는 위에 다른 행이 없으므로 Astrida가 포함된 Customer 행에 대해 NULL을 반환합니다. Betacab 행의 결과는 Astrida에 대한 Sum(Sales)의 값을 보여주며, Canutility의 결과는 Betacab에 대한 Sum(Sales)의 값을 보여줍니다.

레이블이 Sum(Sales)+Above(Sum(Sales))인 열의 경우, Betacab의 행에 행 Betacab + Astrida(539+587)의 Sum(Sales) 값의 덧셈 결과가 표시됩니다. Canutility 행의 결과는 Canutility + Betacab(683+539)의 Sum(Sales) 값의 덧셈 결과가 표시됩니다.

표현식 Sum(Sales)+Above(Sum(Sales), 3)를 사용하여 생성된 레이블이 Above offset 3인 계수에는 인수 offset3으로 설정되어 있으며, 현재 행의 세 번째 위 행에 있는 값을 취하는 결과를 갖습니다. 이는 현재 CustomerSum(Sales) 값을 세 행 위의 Customer 값에 추가합니다. 처음 세 Customer 행에서 반환되는 값은 Null입니다.

아래 테이블은 더 복잡한 계수를 보여줍니다. 하나는 Sum(Sales)+Above(Sum(Sales))에서 생성된 것이며, 하나는 레이블이 Higher?이고 IF(Sum(Sales)>Above(Sum(Sales)), 'Higher')에서 생성된 것입니다.

팁: 이 기능은 테이블 이외의 차트(예: 막대형 차트)에서 사용할 수 있습니다.
팁: 다른 차트 유형인 경우, 함수가 관련된 행을 쉽게 해석할 수 있도록 차트를 일반표 동등 부분으로 변환합니다.

Example 2:  

이 예에 표시된 테이블의 스크린샷에는 시각화에 더 많은 차원이 추가되었습니다. MonthProduct의 측정값 2개를 사용합니다. 차원이 두 개 이상 있는 차트의 경우 Above, Below, TopBottom 함수를 포함하는 표현식의 결과는 Qlik Sense에서 열 차원이 정렬되는 순서에 따라 달라집니다. Qlik Sense에서는 차원의 마지막 정렬 결과인 열 세그먼트에 기반하여 해당 함수를 평가합니다. 열 정렬 순서는 속성 패널의 정렬에서 제어되며 이 순서가 반드시 테이블에 열이 표시되는 순서는 아닙니다.

아래 예 2의 테이블 시각화의 스크린샷에서 최종 정렬 차원은 Month이므로, Above 함수는 개월을 기준으로 평가합니다. 각 달(Jan ~ Aug) (열 세그먼트)에 해당하는 각 Product 값에 대해 일련의 결과가 존재합니다. 이는 일련의 다음 열 세그먼트 즉, 다음 Product에 대한 각 Month로 이어집니다. 각 Product에 대한 각 Customer 값에 해당하는 열 세그먼트 값이 존재하게 됩니다.

예 2의 테이블 시각화.

Example 3:  

아래 예 3의 테이블 시각화의 스크린샷에서 최종 정렬 차원은 Product입니다. 이는 차원 Product을 속성 패널에 있는 정렬 탭의 3번 위치로 이동하여 수행됩니다. 각 Product에 대해 Above 함수가 평가되며, 제품이 AABB 두 가지뿐이므로 각 시리즈에서 Null이 아닌 결과는 하나뿐입니다. Jan 달에 대한 BB 행에서 Above(Sum(Sales))의 값은 46입니다. AA행의 값은 Null입니다. AA 위의 Product 값이 없으므로 모든 달의 각 AA 행의 값은 항상 Null이 됩니다. 두 번째 시리즈는 Feb 달의 Customer 값, AstridaAABB에 대해 평가됩니다. Astrida에 대해 모든 달이 평가되면, 두 번째 CustomerBetacab 그리고 그 다음으로 시퀀스가 반복됩니다.

예 3의 테이블 시각화.

Example 4:  

결과

Above 함수는 범위 함수에 대한 입력으로 사용할 수 있습니다. 합니다(예: RangeAvg (Above(Sum(Sales),1,3))).

Above() 함수에 대한 인수에서 offset가 1로 설정되고 count이 3으로 설정됩니다. 이 함수는 열 세그먼트(행이 있는 곳)의 현재 행 바로 위의 세 행에서 표현식 Sum(Sales)의 결과를 찾습니다. 이 세 값은 제공된 숫자 범위에서 값의 평균을 구하는 RangeAvg() 함수에 대한 입력으로 사용됩니다.

차원으로 Customer가 포함된 테이블은 RangeAvg() 표현식에 대해 다음과 같은 결과를 제공합니다.

Astrida

Betacab

Canutility

Divadip:

-

587

563

603

예에서 사용된 데이터:

Monthnames:

LOAD * INLINE [

Month, Monthnumber

Jan, 1

Feb, 2

Mar, 3

Apr, 4

May, 5

Jun, 6

Jul, 7

Aug, 8

Sep, 9

Oct, 10

Nov, 11

Dec, 12

];

Sales2013:

crosstable (Month, Sales) LOAD * inline [

Customer|Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec

Astrida|46|60|70|13|78|20|45|65|78|12|78|22

Betacab|65|56|22|79|12|56|45|24|32|78|55|15

Canutility|77|68|34|91|24|68|57|36|44|90|67|27

Divadip|57|36|44|90|67|27|57|68|47|90|80|94

] (delimiter is '|');

월을 올바른 순서로 정렬하려면 시각화를 만들 때 속성 패널의 Sorting 섹션으로 이동한 후 Month를 선택하고 Sort by expression 확인란을 선택합니다. 표현식 상자에 Monthnumber를 씁니다.