inlunarweektodate - fonction de script et fonction de graphique
Cette fonction détermine si l'argument timestamp se trouve dans la partie de la semaine lunaire jusqu'à la dernière milliseconde spécifiée dans base_date. Les semaines lunaires figurant dans Qlik Sense sont définies en comptant le 1er janvier comme le premier jour de la semaine.
Il est possible de décaler la semaine lunaire à l'aide de l'argument period_no. period_no est un entier, où la valeur 0 indique la semaine lunaire comprenant l'argument base_date. Les valeurs négatives spécifiées pour period_no indiquent les semaines lunaires passées tandis que les valeurs positives désignent les semaines lunaires à venir.
first_week_day
Décalage pouvant être supérieur ou inférieur à zéro. Il modifie le début de l'année du nombre de jours et/ou de fractions de jour spécifié.
Exemples de script
Exemple
Résultat
inlunarweektodate('12/01/2013', '13/01/2013', 0)
Renvoie True. Car la valeur de timestamp, soit le 12/01/2013, tombe dans la partie de la semaine comprise entre le 08/01/2013 et le 13/01/2013.
inlunarweektodate('12/01/2013', '11/01/2013', 0)
Renvoie False. Car la valeur de timestamp est postérieure à la valeur de base_date, même si les deux dates font partie de la même semaine lunaire, soit avant le 12/01/2012.
inlunarweektodate('12/01/2006', '05/01/2006', 1)
Renvoie True. La définition de la valeur 1 pour period_no a pour effet de retarder la date de référence base_date d'une semaine. De ce fait, la valeur de timestamp tombe dans la partie de la semaine lunaire.
Ajoutez l'exemple de script à votre application et exécutez-le. Pour afficher le résultat, ajoutez les champs répertoriés dans la colonne de résultats à une feuille de votre application.
Cet exemple permet de vérifier si une date de facture tombe dans la partie de la semaine décalée par rapport à la valeur de base_date de quatre semaines.
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 table résultante présente les dates initiales et une colonne contenant la valeur de retour de la fonction inlunarweek().
La fonction renvoie True pour la valeur de InvDate5/2/2013, car la valeur de base_date, soit le 11/01/2013, est décalée de quatre semaines et tombe ainsi dans la partie de la semaine comprise entre le 5/02/2013 et le 07/02/2013.
Table des résultats
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)
Cette page vous a-t-elle aidé ?
Si vous rencontrez des problèmes sur cette page ou dans son contenu – une faute de frappe, une étape manquante ou une erreur technique – dites-nous comment nous améliorer !