inlunarweek – função de script e gráfico
Esta função retornará verdadeiro se timestamp estiver dentro da semana lunar que contém base_date. As semanas lunares no QlikView são definidas ao considerar 1 de janeiro como o primeiro dia da semana.
Sintaxe:
InLunarWeek (timestamp, base_date, period_no[, first_week_day])
Tipo de dados de retorno: Booleano
Argumentos:
Argumento | Descrição |
---|---|
timestamp | A data que você deseja comparar com base_date. |
base_date | Data que é usada para avaliar a semana lunar. |
period_no | A semana lunar pode ser deslocada por period_no. period_n é um inteiro, em que o valor 0 indica a semana lunar que contém base_date. Valores negativos em period_no indicam semanas lunares precedentes e valores positivos indicam semanas lunares sucessivas. |
first_week_day | Um deslocamento que pode ser maior ou menor que zero. Isso muda o início do ano por um número determinado de dias e/ou frações de um dia. |
Exemplo 1:
inlunarweek('12/01/2013', '14/01/2013', 0)
Retorna True. Como o valor de timestamp, 12/01/2013 cai na semana 08/01/2013 até 14/01/2013.
Exemplo 2:
inlunarweek('12/01/2013', '07/01/2013', 0)
Retorna False. Como a base_date 07/01/2013 está na semana lunar definida como de 01/01/2013 até 07/01/2013.
Exemplo 3:
inlunarweek('12/01/2013', '14/01/2013', -1)
Retorna False. Especificar um valor de period_no como -1 desloca a semana para a semana anterior, 01/01/2013 até 07/01/2013.
Exemplo 4:
inlunarweek('07/01/2013', '14/01/2013', -1)
Retorna True. Em comparação com o exemplo anterior, a hora está na semana depois de levar em conta o deslocamento para trás.
Exemplo 5:
inlunarweek('11/01/2006', '08/01/2006', 0, 3)
Retorna False. Porque especificar um valor para first_week_day até 3 significa que o início do ano é calculado a partir de04/01/2013 assim, o valor de base_date cai na primeira semana, e o valor de timestamp cai na semana 11/01/2013 até 17/01/2013.
Exemplo 6:
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 uma data de fatura cai na semana deslocada do valor de base_date por quatro semanas.
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 *,
InLunarWeek(InvDate, '11/01/2013', 4) AS InLWeekPlus4
Resident TempTable;
Drop table TempTable;
A tabela resultante contém as datas originais e uma coluna com o valor de retorno da função inlunarweek().
A função retorna True para o valor de InvDate5/2/2013 porque o valor de base_date, 11/01/2013 é deslocado em quatro semanas e, assim, cai na semana de 5/02/2013 até 11/02/2013.
InvDate | InLWeekPlus4 |
---|---|
28/03/2012 | 0 (False) |
10/12/2012 | 0 (False) |
5/2/2013 | -1 (True) |
31/3/2013 | 0 (False) |
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) |