Free Trial

Alteryx Designer Desktop Discussions

Find answers, ask questions, and share expertise about Alteryx Designer Desktop and Intelligence Suite.
SOLVED

Using operator "+" in THEN clause of IF formula

zoomol
5 - Atom

Hi All,

 

I'm having this IF formula:

 

 

IIF(IsEmpty([Purchased]),
"Beyond Country Lifecycle",

IIF(DateTimeDiff([Purchased],[Report Date],"months")*-1<=6,
"6 First Months",
IIF(DateTimeDiff([Purchased],[Report Date],"months")*-1>6 AND DateTimeDiff([Purchased],[Report Date],"months")*-1<=12,
"Second 6 Months",
IIF(DateTimeDiff([Purchased],[Report Date],"months")*-1>[Refresh Cycle # of Months]+12,
"1 Year Beyond Country Lifecycle",
IIF(DateTimeDiff([Purchased],[Report Date],"months")*-1>[Refresh Cycle # of Months],
"Beyond Country Lifecycle",
IIF([Refresh Cycle # of Months]-DateTimeDiff([Purchased],[Report Date],"months")*-1<=6,
"Up To 6 Months Life Left",
IIF([Refresh Cycle # of Months]-DateTimeDiff([Purchased],[Report Date],"months")*-1>6 AND [Refresh Cycle # of Months]-DateTimeDiff([Purchased],[Report Date],"months")*-1<=12,
"Up To 12 Months Life Left", "Year "+DateTimeDiff([Purchased],[Report Date],"years")*-1+1)))))))

 

 

It is not working, since the last "FALSE"

"Year "+DateTimeDiff([Purchased],[Report Date],"years")*-1+1

argument .

 

The build-in debugger says, that I have "Type mismatch in operator +."

 

I dag a lot of community topics and google, and the answer was always the same: use "+" (Addition) operator to relate string with variable... But, what if I'm using a calculation against the variables? And... I haven't found a solution.

So, how to relate a string "Year " with the calculation of DateTimeDiff([Purchased],[Report Date],"years")*-1+1.

 

Please help.

Thanks in advance

Jarek

4 REPLIES 4
Thableaus
17 - Castor
17 - Castor

Hi @zoomol 

 

Use ToNumber function.

 

ToNumber([Year]) +....

 

If the final result should be a string, then ToString(....) function should be used with the whole result.

 

ToString(ToNumber([Year]) +.....)

 

Cheers,

patrick_digan
17 - Castor
17 - Castor

@zoomol Try using tostring:

"Year "+ToString(DateTimeDiff([Purchased],[Report Date],"years")*-1+1)
patrick_digan
17 - Castor
17 - Castor

@zoomol For what it's worth, here would be another way to basically write the same formula that you have:

1) Create a double field called Months. Since you use it so many times, it's easier to write the formula once.

Months: DateTimeDiff([Report Date],[Purchased],"months")

 

2) Change your formula to this (minus any typos I've made):

IIF(IsEmpty([Purchased]),
"Beyond Country Lifecycle",

IIF([Months]<=6,

"6 First Months",
IIF([Months]<=12,
"Second 6 Months",
IIF([Months]>[Refresh Cycle # of Months]+12,
"1 Year Beyond Country Lifecycle",
IIF([Months]>[Refresh Cycle # of Months],
"Beyond Country Lifecycle",
IIF([Months]>[Refresh Cycle # of Months]-6,
"Up To 6 Months Life Left",
IIF([Months]>[Refresh Cycle # of Months]-12,
"Up To 12 Months Life Left", "Year "+ToString([Months]/12+1))))))))

 

zoomol
5 - Atom

patrick_digan THANK YOU! You made my life easier... I was trying many things, but as they say "it is darkest under the lantern"... Forgot to treat everything as string :) Excel is less picky here :P

Labels
Top Solution Authors