Top - función de gráfico

Top() evalúa una expresión situada en la primera fila (superior) de un segmento de columna en una tabla. La fila para la que se calcula depende del valor de offset. Si está presente, se tomará de forma predeterminada la fila superior. Para los gráficos que no sean tablas, la evaluación de Top() se efectúa en la primera fila de la columna actual en el equivalente de tabla simple del gráfico.

Sintaxis:  

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

Tipo de datos que devuelve: dual

Argumentos:  

Argumento Descripción
expr La expresión o el campo que contiene los datos que se han de medir.
offset

Especificar un offsetde n mayor que 1 nos permite mover la evaluación de la expresión n filas por debajo de la fila superior.

Especificar un número de offset (desplazamiento) negativo hará que la función Top sea equivalente a una función Bottom con el correspondiente número de offset positivo.

count Si se especifica un tercer parámetro count mayor que 1, la función devolverá un rango de valores count, uno por cada una de las últimas filas count del segmento de columna actual. De esta manera, la función puede utilizarse como argumento en cualquiera de las funciones de rango especiales. Funciones de rango
TOTAL

Si la tabla es unidimensional o si se utiliza el cualificador TOTAL como argumento, el segmento de columna actual es siempre igual a la columna entera.

Vea: Definir el ámbito de agregación

Nota: Un segmento de columna se define como un subconjunto consecutivo de celdas que tienen los mismos valores para las dimensiones en la ordenación actual. Las funciones inter-registro se calculan en el segmento de columna excluida la dimensión más a la derecha del gráfico de tabla simple equivalente. Si solo hay una dimensión en el gráfico o si se especifica el calificador TOTAL, la expresión se evalúa en toda la tabla.
Nota: Si la tabla o el equivalente de tabla tiene múltiples dimensiones verticales, el segmento de columna actual incluirá sólo filas con los mismos valores que la fila actual en todas las columnas de dimensión, excepto para la columna que muestra la última dimensión en el orden de campos interno.

Limitaciones:  

Las llamadas recursivas devolverán NULL.

Ejemplos y resultados:  

Ejemplo: 1

Customer Sum(Sales) Top(Sum(Sales)) Sum(Sales) + Top(Sum(Sales)) Top offset 3
  2566 587 3153 3249
Astrida 587 587 1174 1270
Betacab 539 587 1126 1222
Canutility 683 587 1270 1366
Divadip 757 587 1344 1440

En la representación del gráfico de tabla mostrado en este ejemplo, la tabla se crea a partir de la dimensión Customer y las medidas: Sum(Sales) y Top(Sum(Sales)).

La columna Top(Sum(Sales)) devuelve 587 para todas las filas porque éste es el valor de la fila superior: Astrida.

La tabla también muestra medidas más complejas: una creada a partir de Sum(Sales)+Top(Sum(Sales)) y otra etiquetada Top offset 3, que se crea utilizando la expresión Sum(Sales)+Top(Sum(Sales), 3) y tiene el argumento offset establecido en 3. Agrega el valor Sum(Sales) para la fila actual al valor de la tercera fila desde la fila superior, es decir, la fila actual más el valor de Canutility.

Ejemplo: 2

En las representaciones de los gráficos de tabla mostrados en este ejemplo, se han añadido más dimensiones a los gráficos: Month y Product. Para gráficos con más de una dimensión, los resultados de las expresiones que contienen las funciones Above, Below, Top y Bottom dependen del orden en que QlikView clasifica las dimensiones de columna. QlikView evalúa las funciones basándose en los segmentos de columna que resultan de la dimensión que se ordena en último lugar. El criterio de ordenación de columnas se controla en el panel de propiedades, en Ordenación y no es necesariamente el orden en el que las columnas aparecen en una tabla. (Algunas filas no se muestran, para ahorrar espacio.)

Customer Product Month Sum(Sales) First value
      2566 -
Astrida AA Jan 46 46
Astrida AA Feb 60 46
Astrida AA Mar 70 46
... ... ... ... ...
Astrida AA Sep 78 46
Astrida AA Oct 12 46
Astrida AA Nov 78 46
Astrida AA Dec 22 46
Astrida BB Jan 46 46
Primera tabla para el ejemplo 2. El valor de Top para la medida First value basado en Month (Jan).
Customer Product Month Sum(Sales) First value
      2566 -
Astrida AA Jan 46 46
Astrida BB Jan 46 46
Astrida AA Feb 60 60
Astrida BB Feb 60 60
Astrida AA Mar 70 70
Astrida BB Mar 70 70
Astrida AA Apr 13 13
Astrida BB Apr 13 13
Segunda tabla para el ejemplo 2. El valor de Top para la medida First value basado en Product (AA paraAstrida).

Le remitimos al Ejemplo: 2 de la función Above para más detalles.

Ejemplo: 3

Resultado

La función Top puede utilizarse como entrada para las funciones de rango. Por ejemplo: RangeAvg (Top(Sum(Sales),1,3)).

En los argumentos de la función Top(), offset se establece en 1 y count se establece en 3. La función busca los resultados de la expresión Sum(Sales) en las tres filas que comienzan con la fila inmediatamente debajo de la fila inferior del segmento de columna (debido al valor offset=1) y en las dos filas debajo (donde hay una fila). Estos tres valores se utilizan como entrada para la función RangeAvg(), que buscará la media de los valores en el rango de números proporcionado.

Una tabla con el valor Customer como dimensión ofrecerá los resultados siguientes para la expresión RangeAvg().

 
Astrida
Betacab
Canutility
Divadip:
603
603
603
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 '|');

Para ordenar los meses correctamente cuando cree sus gráficos, diríjase a la página Sort del panel de propiedades, y seleccione la casilla Expression en Sort by. En el cuadro de expresión, escriba Monthnumber.