Ir para conteúdo principal

inmonths – função de script e gráfico

Essa função verifica se um carimbo de data/hora está no mesmo mês, bimestre, trimestre, período de quatro meses ou meio ano da data base. Também é possível descobrir se uma data/hora está dentro de um período de tempo anterior ou seguinte.

Sintaxe:  

InMonths(n_months, timestamp, base_date, period_no [, first_month_of_year])

Tipo de dados de retorno: Booleano

Argumentos:  

Argumentos InMonths
Argumento Descrição
n_months

O número de meses que define o período. Um inteiro ou uma expressão que é resolvida como um inteiro, que deve ser um dos seguintes: 1 (equivalente à função inmonth()), 2 (bimestre), 3 (equivalente à função inquarter()), 4 (quadrimestre) ou 6 (semestre).

timestamp A data que você deseja comparar com base_date.
base_date Data que é usada para avaliar o período.
period_no

O período pode ser deslocado por period_no, um inteiro ou expressão que resolve um inteiro, no qual o valor 0 indica o período que contém base_date. Valores negativos em period_no indicam períodos precedentes e valores positivos indicam períodos sucessivos.

first_month_of_year

Se desejar trabalhar com anos (fiscais) que não comecem em janeiro, indique um valor entre 2 e 12 em first_month_of_year.

Exemplos e resultados:  

Esses exemplos usam o formato de data DD/MM/YYYY. O formato de data é especificado no comando SET DateFormat na parte superior do seu script de carregamento. Altere o formato nos exemplos para atender às suas necessidades.

Exemplo 1:  

inmonths(4, '25/01/2013', '25/04/2013', 0)

Retorna True. Como o valor de timestamp, 25/01/2013, fica dentro do período de quatro meses 01/01/2013 até 30/04/2013, em que fica o valor de base_date, 25/04/2013.

Exemplo 2:  

inmonths(4, '25/05/2013', '25/04/2013', 0)

Retorna False. Porque 25/05/2013 está fora do mesmo período que o exemplo anterior.

Exemplo 3:  

inmonths(4, '25/11/2012', '01/02/2013', -1 )

Retorna True. Como o valor de period_no, -1, muda o período de busca de volta para um período de quatro meses (o valor de n-months), que deixa o período de busca de 01/09/2012 para 31/12/2012.

Exemplo 4:  

inmonths( 4, '25/05/2006', '01/03/2006', 0, 3)

Retorna True. Como o valor de first_month_of_year é definido para 3, o que torna o período de busca 01/03/2006 até 30/07/2006 em vez de 01/01/2006 até 30/04/2006.

Exemplo 5:  

Adicione o script de exemplo ao seu documento e execute-o. Em seguida, adicione pelo menos os campos listados na coluna de resultados a um documento para ver o resultado.

Este exemplo verifica se a data da fatura na tabela cai na parte do período de dois meses que inclui base_date deslocada para a frente por um período de dois meses (especificando o period_no como 1).

TempTable:

LOAD RecNo() as InvID, * Inline [

InvDate

28/03/2012

10/12/2012

5/2/2013

31/3/2013

19/5/2013

15/9/2013

11/12/2013

2/3/2014

14/5/2014

13/6/2014

7/7/2014

4/8/2014

];

 

InvoiceData:

LOAD *,

InMonths(2, InvDate, '11/02/2013', 1) AS InMthsPlus1

Resident TempTable;

Drop table TempTable;

A tabela resultante contém as datas originais e uma coluna com o valor de retorno da função InMonths().

O período de busca é 01/03/2013 até 30/04/2013, porque o valor debase_date é deslocado dois meses para a frente, a partir do valor na função (11/02/2013).

Resultados do exemplo 5
InvDate InMthsPlus1
28/03/2012 0 (False)
10/12/2012 0 (False)
5/2/2013 0 (False)
31/3/2013 -1 (True)
19/5/2013 0 (False)
15/9/2013 0 (False)
11/12/2013 0 (False)
2/3/2014 0 (False)
14/5/2014 0 (False)
13/6/2014 0 (False)
7/7/2014 0 (False)
4/8/2014 0 (False)

Esta página ajudou?

Se você encontrar algum problema com esta página ou seu conteúdo - um erro de digitação, uma etapa ausente ou um erro técnico - informe-nos como podemos melhorar!

Participe do Programa de Modernização do Analytics

Remove banner from view

Modernize sem comprometer seus valiosos aplicativos QlikView com o Programa de Modernização do Analytics. Clique aqui para mais informações ou entre em contato: ampquestions@qlik.com