Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Register now to learn Fabric in free live sessions led by the best Microsoft experts. From Apr 16 to May 9, in English and Spanish.

Reply
AKARSEVGI
Helper I
Helper I

MULTIPLE IFs

EXCHRATE2 = IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) <> "TL" ,
IF ( RELATED('SHEAD-SALHEAD'[EXCHRATE]) <= 1 ,
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "EUR" ,RELATED('FITEM-FINITEM'[HEXCHRATE])),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "USD" ,(RELATED('CURRENCY'[EUR]) /RELATED('FITEM-FINITEM'[HEXCHRATE]) * RELATED('CURRENCY'[USD]))),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "GBP" ,(RELATED('CURRENCY'[EUR]) /RELATED('FITEM-FINITEM'[HEXCHRATE]) * RELATED('CURRENCY'[GBP]))),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "AUD" ,(RELATED('CURRENCY'[EUR]) /RELATED('FITEM-FINITEM'[HEXCHRATE]) * RELATED('CURRENCY'[AUD]))),

RELATED('FITEM-FINITEM'[HEXCHRATE])
,
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "EUR" ,RELATED('SHEAD-SALHEAD'[EXCHRATE])),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "USD" ,(RELATED('CURRENCY'[EUR]) / RELATED('SHEAD-SALHEAD'[EXCHRATE]) * RELATED('CURRENCY'[USD]))),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "GBP" ,(RELATED('CURRENCY'[EUR]) / RELATED('SHEAD-SALHEAD'[EXCHRATE]) * RELATED('CURRENCY'[GBP]))),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "AUD" ,(RELATED('CURRENCY'[EUR]) / RELATED('SHEAD-SALHEAD'[EXCHRATE]) * RELATED('CURRENCY'[AUD]))),
 
RELATED('SHEAD-SALHEAD'[EXCHRATE])
 
)
,
RELATED('CURRENCY'[EUR])
)
 
 
Error: Too many arguments were passed to the IF function. The maximum argument count for the function is 3.
How can I fix it?
1 ACCEPTED SOLUTION
v-rongtiep-msft
Community Support
Community Support

Hi @AKARSEVGI ,

Please have a try.

EXCHRATE2 = IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) <> "TL" &&RELATED('SHEAD-SALHEAD'[EXCHRATE]) <= 1 &&RELATED('SHEAD-SALHEAD'[CURRENCY]) = "EUR" ,RELATED('FITEM-FINITEM'[HEXCHRATE]), IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "USD" ,(RELATED('CURRENCY'[EUR]) /RELATED('FITEM-FINITEM'[HEXCHRATE]) * RELATED('CURRENCY'[USD])),
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "GBP" ,(RELATED('CURRENCY'[EUR]) /RELATED('FITEM-FINITEM'[HEXCHRATE]) * RELATED('CURRENCY'[GBP])),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "AUD" ,(RELATED('CURRENCY'[EUR]) /RELATED('FITEM-FINITEM'[HEXCHRATE]) * RELATED('CURRENCY'[AUD])),
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "EUR" ,RELATED('SHEAD-SALHEAD'[EXCHRATE]),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "USD" ,(RELATED('CURRENCY'[EUR]) / RELATED('SHEAD-SALHEAD'[EXCHRATE]) * RELATED('CURRENCY'[USD])),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "GBP" ,(RELATED('CURRENCY'[EUR]) / RELATED('SHEAD-SALHEAD'[EXCHRATE]) * RELATED('CURRENCY'[GBP])),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "AUD" ,(RELATED('CURRENCY'[EUR]) / RELATED('SHEAD-SALHEAD'[EXCHRATE]) * RELATED('CURRENCY'[AUD])),
 
RELATED('SHEAD-SALHEAD'[EXCHRATE])
,
RELATED('CURRENCY'[EUR])
))))))))

Please use the correct if statement.

I have created a simple sample, please refer to it to see if it helps you.

vpollymsft_0-1655345743405.png

Then create a column.

Column =
IF (
    ( 'SHEAD-SALHEAD'[EXCHRATE] ) <= 20
        && ( 'SHEAD-SALHEAD'[CURRENCY] ) = "EUR",
    "1",
    IF (
        'SHEAD-SALHEAD'[CURRENCY] = "AUD"
            && 'SHEAD-SALHEAD'[EXCHRATE] >= 18,
        "aUD ",
        IF (
            'SHEAD-SALHEAD'[CURRENCY] = "GBP"
                && 'SHEAD-SALHEAD'[EXCHRATE] <= 14,
            "good gbp",
            "unsatisfy"
        )
    )
)

The meaning of the formula: 

[CURRENCY] column is  equal to EUR and the value [EXCHRATE] is less than 20, then output 1, if  [CURRENCY] column is  equal to AUD and the value [EXCHRATE] is less than 18,then output aUD, if  [CURRENCY] column is  equal to GBP and the value [EXCHRATE] is less than 14,then output good gbp, All other results that do not satisfy the above conditions are output “Unsatisfy".

vpollymsft_1-1655346207328.png

 

If I have misunderstood your meaning, please provide some simple sample data without privacy information and your desired output.

 

How to Get Your Question Answered Quickly 

 

 Best Regards
Community Support Team _ Polly

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

View solution in original post

1 REPLY 1
v-rongtiep-msft
Community Support
Community Support

Hi @AKARSEVGI ,

Please have a try.

EXCHRATE2 = IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) <> "TL" &&RELATED('SHEAD-SALHEAD'[EXCHRATE]) <= 1 &&RELATED('SHEAD-SALHEAD'[CURRENCY]) = "EUR" ,RELATED('FITEM-FINITEM'[HEXCHRATE]), IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "USD" ,(RELATED('CURRENCY'[EUR]) /RELATED('FITEM-FINITEM'[HEXCHRATE]) * RELATED('CURRENCY'[USD])),
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "GBP" ,(RELATED('CURRENCY'[EUR]) /RELATED('FITEM-FINITEM'[HEXCHRATE]) * RELATED('CURRENCY'[GBP])),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "AUD" ,(RELATED('CURRENCY'[EUR]) /RELATED('FITEM-FINITEM'[HEXCHRATE]) * RELATED('CURRENCY'[AUD])),
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "EUR" ,RELATED('SHEAD-SALHEAD'[EXCHRATE]),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "USD" ,(RELATED('CURRENCY'[EUR]) / RELATED('SHEAD-SALHEAD'[EXCHRATE]) * RELATED('CURRENCY'[USD])),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "GBP" ,(RELATED('CURRENCY'[EUR]) / RELATED('SHEAD-SALHEAD'[EXCHRATE]) * RELATED('CURRENCY'[GBP])),
 
IF(RELATED('SHEAD-SALHEAD'[CURRENCY]) = "AUD" ,(RELATED('CURRENCY'[EUR]) / RELATED('SHEAD-SALHEAD'[EXCHRATE]) * RELATED('CURRENCY'[AUD])),
 
RELATED('SHEAD-SALHEAD'[EXCHRATE])
,
RELATED('CURRENCY'[EUR])
))))))))

Please use the correct if statement.

I have created a simple sample, please refer to it to see if it helps you.

vpollymsft_0-1655345743405.png

Then create a column.

Column =
IF (
    ( 'SHEAD-SALHEAD'[EXCHRATE] ) <= 20
        && ( 'SHEAD-SALHEAD'[CURRENCY] ) = "EUR",
    "1",
    IF (
        'SHEAD-SALHEAD'[CURRENCY] = "AUD"
            && 'SHEAD-SALHEAD'[EXCHRATE] >= 18,
        "aUD ",
        IF (
            'SHEAD-SALHEAD'[CURRENCY] = "GBP"
                && 'SHEAD-SALHEAD'[EXCHRATE] <= 14,
            "good gbp",
            "unsatisfy"
        )
    )
)

The meaning of the formula: 

[CURRENCY] column is  equal to EUR and the value [EXCHRATE] is less than 20, then output 1, if  [CURRENCY] column is  equal to AUD and the value [EXCHRATE] is less than 18,then output aUD, if  [CURRENCY] column is  equal to GBP and the value [EXCHRATE] is less than 14,then output good gbp, All other results that do not satisfy the above conditions are output “Unsatisfy".

vpollymsft_1-1655346207328.png

 

If I have misunderstood your meaning, please provide some simple sample data without privacy information and your desired output.

 

How to Get Your Question Answered Quickly 

 

 Best Regards
Community Support Team _ Polly

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

Helpful resources

Announcements
Microsoft Fabric Learn Together

Microsoft Fabric Learn Together

Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City

PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

April Fabric Community Update

Fabric Community Update - April 2024

Find out what's new and trending in the Fabric Community.