Ir para conteúdo principal

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

Esta função descobre se um carimbo de data/hora se enquadra na parte de um período do mês, bimestre, trimestre, período de quatro meses ou semestre até e incluindo o último milissegundo de base_date. 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 InMonthsToDate
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:  

inmonthstodate(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é o final de 25/04/2013, em que fica o valor de base_date, 25/04/2013.

Exemplo 2:  

inmonthstodate(4, '26/04/2013', '25/04/2006', 0)

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

Exemplo 3:  

inmonthstodate(4, '25/09/2005', '01/02/2006', -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/2005 para 01/02/2006.

Exemplo 4:  

inmonthstodate(4, '25/04/2006', '01/06/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é 01/06/2006 em vez de 01/05/2006 até 01/06/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 até e incluindo a base_date deslocada para a frente por quatro períodos de dois meses (especificando o period_no como 4).

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 *,

InMonthsToDate(2, InvDate, '15/02/2013', 4) AS InMths2DPlus4

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 pesquisa é de 01/09/2013 até 15/10/2013, porque o valor debase_date é deslocado 8 meses para a frente, a partir do valor na função (15/02/2013).

Resultados do exemplo 5
InvDate InMths2DPlus4
28/03/2012 0 (False)
10/12/2012 0 (False)
5/2/2013 0 (False)
31/3/2013 0 (False)
19/5/2013 0 (False)
15/9/2013 -1 (True)
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