inlunarweektodate - funzione dello script e del grafico
Questa funzione restituisce true se timestamp ricade all'interno della parte della settimana lunare fino a includere l'ultimo millisecondo di base_date. Le settimane lunari in QlikView vengono definite calcolando il 1° gennaio come primo giorno della settimana.
Sintassi:
InLunarWeekToDate (timestamp, base_date, period_no [, first_week_day])
Restituisce il tipo di dati: Booleano
Argomenti:
Argomento | Descrizione |
---|---|
timestamp | La data da confrontare con base_date. |
base_date | La data utilizzata per valutare la settimana lunare. |
peroid_no | La settimana lunare può essere differita mediante period_no. period_no è un numero intero, in cui il valore 0 indica la settimana lunare che contiene base_date. I valori negativi di period_no indicano le settimane lunari precedenti, mentre i valori positivi indicano le settimane lunari successive. |
week_start | Un differimento che può essere maggiore o minore di zero. Ciò modifica l'inizio dell'anno in base al numero specificato di giorni e/o frazioni di un giorno. |
Esempio 1:
inlunarweektodate('12/01/2013', '13/01/2013', 0)
Restituisce True. Perché il valore di timestamp, 12/01/2013 ricade nella parte della settimana da 08/01/2013 a 13/01/2013.
Esempio 2:
inlunarweektodate('12/01/2013', '11/01/2013', 0)
Restituisce False. Perché il valore di timestamp è successivo al valore di base_date anche se le due date si trovano nella stessa settimana lunare prima di 12/01/2012.
Esempio 3:
inlunarweektodate('12/01/2006', '05/01/2006', 1)
Restituisce True. Specificando un lavoro pari a 1 per period_no, base_date slitta in avanti di una settimana, pertanto il valore di timestamp ricade nella parte della settimana lunare.
Esempio 4:
Aggiungere lo script di esempio al documento ed eseguirlo. Aggiungere quindi a un foglio del documento almeno i campi elencati nella colonna dei risultati per visualizzare il risultato.
Questo esempio consente di controllare se una data della fattura ricade nella parte della settimana che è slittata di quattro settimane dal valore di base_date.
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 *,
InLunarWeekToDate(InvDate, '07/01/2013', 4) AS InLWeek2DPlus4
Resident TempTable;
Drop table TempTable;
La tabella risultante contiene le date originali e una colonna con il valore restituito della funzione inlunarweek().
La funzione restituisce True per il valore di InvDate5/2/2013 perché il valore di base_date, 11/01/2013, è slittato di quattro settimane e pertanto ricade nella parte della settimana da 5/02/2013 a 07/02/2013.
InvDate | InLWeek2DPlus4 |
---|---|
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) |