Med den här funktionen får vi reda på om en tidsmarkör faller inom samma månad, tvåmånadersperiod, fyramånadersperiod eller halvår som basdatum. Det går även att se om tidsmarkören finns inom en föregående eller senare tidsperiod.
I Qlik Sense, representeras det booleska sanna värdet av -1, och det falska värdet representeras av 0.
inmonths()-funktionen delar in året i segment baserat på det n_months-argument som tillhandahålls. Därefter avgör den huruvida varje tidsmarkör som utvärderas infaller i samma segment som base_date-argumentet. Men om ett period_no-argument tillhandahålls avgör funktionen huruvuda tidsmarkörerna infaller under en tidigare eller följande period från base_date.
Följande segment av året är tillgängliga i funktionen som n_month-argument.
n_month-argument
Period
Antal månader
månad
1
två månader
2
kvartal
3
fyra månader
4
halvår
6
Användning
Funktionen inmonths() returnerar ett booleskt resultat. Vanligtvis kommer denna typ av funktion att användas som ett villkor i en if expression. Genom att använda inmonths()-funktionen kan du välja den period som du vill utvärdera. Exempelvis, låta användaren identifiera produkter som tillverkats under en månad, ett kvartal eller ett halvår i en viss period.
Returnerad datatyp: Boolesk
I Qlik Sense, representeras det booleska sanna värdet av -1, och det falska värdet representeras av 0.
Argument
Argument
Beskrivning
n_months
Antalet månader som definierar perioden. Ett heltal eller uttryck vars resultat blir ett heltal som ska vara antingen: 1 (motsvaras av inmonth()-funktionen), 2 (tvåmånadersperiod), 3 (motsvaras av inquarter()-funktionen), 4 (fyramånadersperiod) eller 6 (halvår).
timestamp
Det datum du vill jämföra mot base_date.
base_date
Datum som används för att utvärdera perioden.
period_no
Periodens startpunkt kan flyttas med period_no, ett heltal, eller ett uttryck som resulterar i ett heltal, där värdet 0 anger den period som innehåller base_date. Negativa värden i period_no anger föregående perioder och positiva värden anger efterföljande perioder.
first_month_of_year
Om du vill arbeta med (budget)år som inte börjar i januari kan du ange ett värde mellan 2 och 12 i first_month_of_year.
Du kan använda följande värden för att ställa in den första månaden på året i argumentet first_month_of_year:
first_month_of_year values
Månad
Värde
februari
2
mars
3
april
4
Maj
5
juni
6
juli
7
augusti
8
september
9
oktober
10
november
11
december
12
Lokala inställningar
Om inget annat anges använder exemplen i detta ämne följande datumformat: MM/DD/ÅÅÅÅ. Datumformatet anges i SET DateFormat-satsen i datainläsningsskriptet. Förvald datumformatering kan vara annorlunda i ditt system, på grund av dina regionala inställningar och andra faktorer. Du kan ändra formaten i exemplen nedan så att det passar dina krav. Eller så kan du ändra formaten i ditt laddningsskript så att de matchar dessa exempel. Mer information finns i Ändra regioninställningar för appar och skript.
Regionala standardinställningar i appar baseras på användarprofilen. Dessa regionala formatinställningar är inte relaterade till språket som visas i Qlik Cloud användargränssnittet. Qlik Cloud kommer att visas på samma språk som webbläsaren du använder.
Returnerar TRUE Eftersom värdet för timestamp, 01/25/2013, befinner sig inom fyramånadersperioden 2013-01-01 till 2013-04-30 där värdet för base_date, 04/25/2013 finns.
inmonths(4, '05/25/2013', '04/25/2013', 0)
Returnerar FALSE Eftersom 05/25/2013 är utanför samma period som i förra exemplet.
inmonths(4, '11/25/2012', '02/01/2013', -1 )
Returnerar TRUE Eftersom värdet för period_no, -1, flyttar sökperioden bakåt en period på fyra månader (värdet för n-months), vilket gör sökperioden till 09/01/2012 till 12/31/2012.
inmonths(4, '05/25/2006', '03/01/2006', 0, 3)
Returnerar TRUE Eftersom värdet för first_month_of_year är angett som 3, vilket gör sökperioden till 2006-03-01 till 2006-07-30 istället för 2006-01-01 till 2006-04-30.
Exempel 1 – inga ytterligare argument
Översikt
Öppn skriptredigeraren och lägg till laddningsskriptet nedan till en ny flik.
Laddningsskriptet innehåller:
En datauppsättning som innehåller en uppsättning transaktioner för 2022 laddas i en tabell som heter Transactions.
En föregående laddning med en extra variabel, in_months, som avgör vilka transaktioner som ägde rum under samma kvartal som 15 maj 2022.
Ladda data och öppna ett ark. Skapa en ny tabell och lägg till dessa fält som dimensioner:
date
in_months
Resultattabell
date
in_months
2/19/2022
0
3/7/2022
0
3/30/2022
0
4/5/2022
-1
4/16/2022
-1
5/1/2022
-1
5/7/2022
-1
5/22/2022
-1
6/15/2022
-1
6/26/2022
-1
7/9/2022
0
7/22/2022
0
7/23/2022
0
7/27/2022
0
8/2/2022
0
8/8/2022
0
8/19/2022
0
9/26/2022
0
10/14/2022
0
10/29/2022
0
in_months-fältet skapas i föregående LOAD-sats med hjälp av funktionen inmonths(). Det första argumentet som tillhandahålls är 3, som delar upp året i kvartalssegment. Det andra argumentet som anges identifierar vilket fält som utvärderas, datumfältet i det här exemplet. Det tredje argumentet är ett hårdkodat datum för 15 maj, som är base_date och ett period_no av 0 är det sista argumentet.
Maj infaller under årets andra kvartal. Därför kommer alla transaktioner som sker mellan 1 april och 30 juni att returnera det booleska resultatet TRUE. Det här valideras i resultattabellen.
Exempel 2 – period_no
Översikt
Öppn skriptredigeraren och lägg till laddningsskriptet nedan till en ny flik.
Laddningsskriptet innehåller:
En datauppsättning som innehåller en uppsättning transaktioner för 2022 laddas i en tabell som heter Transactions.
En föregående laddning med en extra variabel, previous_quarter, som avgör huruvida transaktionerna ägde rum under kvartalet före 15 maj 2022.
Ladda data och öppna ett ark. Skapa en ny tabell och lägg till dessa fält som dimensioner:
date
previous_quarter
Resultattabell
date
föregående kvartal
2/19/2022
-1
3/7/2022
-1
3/30/2022
-1
4/5/2022
0
4/16/2022
0
5/1/2022
0
5/7/2022
0
5/22/2022
0
6/15/2022
0
6/26/2022
0
7/9/2022
0
7/22/2022
0
7/23/2022
0
7/27/2022
0
8/2/2022
0
8/8/2022
0
8/19/2022
0
9/26/2022
0
10/14/2022
0
10/29/2022
0
Funktionen utvärderar huruvuda transaktioner inträffade under årets första kvartal genom att använda -1 som period_no argument i inmonths()-funktionen. 15 maj är base_date och infaller under årets andra kvartal (april-juni).
Därför kommer alla transaktioner som sker mellan januari och mars returnera det booleska resultatet TRUE.
Exempel 3 – first_month_of_year
Översikt
Öppn skriptredigeraren och lägg till laddningsskriptet nedan till en ny flik.
Laddningsskriptet innehåller:
En datauppsättning som innehåller en uppsättning transaktioner för 2022 laddas i en tabell som heter Transactions.
En föregående laddning med en extra variabel, in_months, som avgör vilka transaktioner som ägde rum under samma kvartal som 15 maj 2022.
I det här exemplet är organisationspolicyn att mars är den första månaden i räkenskapsåret.
Ladda data och öppna ett ark. Skapa en ny tabell och lägg till dessa fält som dimensioner:
date
in_months
Resultattabell
date
in_months
2/19/2022
0
3/7/2022
-1
3/30/2022
-1
4/5/2022
-1
4/16/2022
-1
5/1/2022
-1
5/7/2022
-1
5/22/2022
-1
6/15/2022
0
6/26/2022
0
7/9/2022
0
7/22/2022
0
7/23/2022
0
7/27/2022
0
8/2/2022
0
8/8/2022
0
8/19/2022
0
9/26/2022
0
10/14/2022
0
10/29/2022
0
Genom att använda 3som first_month_of_year-argument i inmonths()-funktionen startar funktionen året den 1 mars. inmonths()-funktionen delar sedan upp året i kvartal: mar-maj, jun-aug, sep-nov, dec-feb. Därför infaller 15 maj under årets första kvartal (mars-maj).
Alla transaktioner som inträffar under dessa månader returnerar det booleska värdet TRUE.
Exempel 4 – Diagramobjektexempel
Översikt
Samma datauppsättning och scenario som det första exemplet används.
I det här exemplet är dock datauppsättningen oförändrad och har laddats i programmet. Beräkningen som avgör om transaktioner har skett i samma kvartal som den 15 maj 2022 skapas som ett mått i ett diagram i appen.
Ladda data och öppna ett ark. Skapa en ny tabell och lägg till det här fältet som en dimension:
date
För att beräkna om transaktioner ägde rum under samma kvartal som 15 maj skapar du följande mått:
=inmonths(3,date,'05/15/2022', 0)
Resultattabell
date
=inmonths(3,date,'05/15/2022', 0)
2/19/2022
0
3/7/2022
0
3/30/2022
0
4/5/2022
-1
4/16/2022
-1
5/1/2022
-1
5/7/2022
-1
5/22/2022
-1
6/15/2022
-1
6/26/2022
-1
7/9/2022
0
7/22/2022
0
7/23/2022
0
7/27/2022
0
8/2/2022
0
8/8/2022
0
8/19/2022
0
9/26/2022
0
10/14/2022
0
10/29/2022
0
in_months-fältet skapas i diagrammet genom att använda inmonths()-funktionen. Det första argumentet som tillhandahålls är 3, som delar upp året i kvartalssegment. Det andra argumentet som anges identifierar vilket fält som utvärderas, datumfältet i det här exemplet. Det tredje argumentet är ett hårdkodat datum för 15 maj, som är base_date och ett period_no av 0 är det sista argumentet.
Maj infaller under årets andra kvartal. Därför kommer alla transaktioner som sker mellan 1 april och 30 juni att returnera det booleska resultatet TRUE. Det här valideras i resultattabellen.
Exempel 5 – Scenario
Översikt
Öppn skriptredigeraren och lägg till laddningsskriptet nedan till en ny flik.
Laddningsskriptet innehåller:
En datauppsättning laddas i en tabell som heter Products.
Tabellen innehåller följande fält:
produkt-ID
produkttyp
tillverkningsdatum
kostnadspris
Slutanvändaren vill ha ett diagramobjekt som visar, per produkttyp, kostnaden för produkterna som tillverkats under det första segmentet av 2021. Användaren vill kunna definiera det här segmentets längd.
inmonths()-funktionen använder användarindata som sitt argument för att definiera storleken på startsegmentet för året. Funktionen skickar tillverkningsdatumet för var och en av produkterna som inmonths()-funktionens andra argument. Genom att använda 1 januari som det tredje argumentet i inmonths()-funktionen kommer produkter med tillverkningsdatum under årets öppningssegment att returnera det booleska värdet TRUE och därför kommer summafunktionen att lägga till kostnaden för de här produkterna.
Var den här sidan till hjälp för dig?
Om du hittar några fel på denna sida eller i innehållet – ett stavfel, ett steg som saknas eller ett tekniskt fel – berätta för oss så att vi kan blir bättre!