data:image/s3,"s3://crabby-images/72807/7280789bb888da3eaa54e3cb689ec358ca2bdb47" alt="Contributor II"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Using a variable in a Set modifier
Hello,
I am trying to use a variable in a set modifier but have trouble doing it.
BAsically I would like to have something like this :
sum( {< [demand week]={" '<='&$(vActiveWeek)"} >} Forecast_M1)
with vActiveWeek = 202501 for instance (I checked the value of vActiveWeek)
I have tried as well :
sum( {< [demand week]={" <=$(vActiveWeek)"} >} Forecast_M1)
but it does not work.
and when I try :
sum( {< [demand week]={" <=202501"} >} Forecast_M1)
it work perfectly well.
Any idea of what I am doing wrong to use the varaible in the set modifier ?
Thank you
Chloé
Accepted Solutions
data:image/s3,"s3://crabby-images/58c5b/58c5b0d39ca0ccf33eceef9350b4faf96961e5b0" alt="Specialist III"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi @chloeM , did you create the variable in script ? if not, try this :
please see that they are right aligned, meaning that they are recognized as numbers
data:image/s3,"s3://crabby-images/72807/7280789bb888da3eaa54e3cb689ec358ca2bdb47" alt="Contributor III"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
@chloeM Your set expression is right check the expression which is giving you value of vActiveWeek ?
Since same set expression is working for me.
data:image/s3,"s3://crabby-images/72807/7280789bb888da3eaa54e3cb689ec358ca2bdb47" alt="Contributor II"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thanks for your qlik reply, here is the expression of the variable :
Year(Today()) & num(Week(Today()),'00')
data:image/s3,"s3://crabby-images/72807/7280789bb888da3eaa54e3cb689ec358ca2bdb47" alt="Contributor III"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
@chloeM In variable definition use =Year(max(CREATEDON)) & num(Week(max(CREATEDON)),'00')
then set expression as =sum( {< [demand week] ={"<=$(vWeek)"} >} Forecast_M1)
data:image/s3,"s3://crabby-images/93275/932755833c4bd87f0d98f2e2ed2b534603b3948f" alt="marcus_sommer marcus_sommer"
data:image/s3,"s3://crabby-images/368bc/368bcf7eceba9f687523d207ee8d6d000e70ad9d" alt="MVP"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Your variable contained a string and not a numeric value. You may change the value to:
year(today()) * 100 + week(today())
data:image/s3,"s3://crabby-images/58c5b/58c5b0d39ca0ccf33eceef9350b4faf96961e5b0" alt="Specialist III"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi @chloeM , did you create the variable in script ? if not, try this :
please see that they are right aligned, meaning that they are recognized as numbers
data:image/s3,"s3://crabby-images/72807/7280789bb888da3eaa54e3cb689ec358ca2bdb47" alt="Contributor II"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Indeed, it worked when I put my variable in the script.
I have no idea why it did not work when the variable was set otherwise, I have tested all the solutions provided before, my variable was numeric (I could do operations on it) and I had tested in a table that [demand week]<=$(vActiveWeek) worked...
I will stick to the variable in the script but if someone have a possible explanation I am interested...
Thank you very much.
data:image/s3,"s3://crabby-images/93275/932755833c4bd87f0d98f2e2ed2b534603b3948f" alt="marcus_sommer marcus_sommer"
data:image/s3,"s3://crabby-images/368bc/368bcf7eceba9f687523d207ee8d6d000e70ad9d" alt="MVP"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
It's not quite the same if a value is used within a math operation or as part of a numeric comparison.
Many tools apply a conversion by measurements like this:
'2' * 1
which will then often result in 2 (of course depending on the tool and the used context). It's an implicit version of functions like num#(). This won't happens (at least I don't know that any tool does it) by:
'2' >= 1
Therefore my above suggestion to create (always) numeric values which is often not more difficult as concatenating numbers. Not only in variables else also for all fields which are used for any kind of calculating/matching - and ideally pure numbers without any formatting. It avoids a lot of trouble ...
data:image/s3,"s3://crabby-images/58c5b/58c5b0d39ca0ccf33eceef9350b4faf96961e5b0" alt="Specialist III"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
hope this help!
did you find the difference?
data:image/s3,"s3://crabby-images/452a4/452a4061d72571f9aa0aec88bfd0dae68047fb28" alt=""