data:image/s3,"s3://crabby-images/2562a/2562ad8f2234fe14cd3f382ff028f9cd1923ba87" alt="Benjamin_Jones Benjamin_Jones"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 04, 2021 11:28 AM
Hi everyone,
We have updated our service pricing in October and I’m trying to update the calculation for services rendered after 10/1. In the below code {Direct Time} is {Direct TIme} + {Indirect Time}. Is it possible to use calculations like this within a nested IF statement?
(IF
AND(
{FY}=“22”,
{MM}>=“10”,
({Total Time} * {Rate by FY by MM})+{Pass through Materials},
({Direct Time} * {Rate by FY by MM})+{Pass through Materials},
)
)
Best,
Ben
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 04, 2021 12:20 PM
Hi,
it seems like something not OK in your syntax
assuming you want something like
IF (Statement1 AND Statement2 AND Statement3) then X else Y,
in your text, there are 4 statements and no X and Y
it should be written as (added more linebreaks to highlight statement part):
IF(
AND(
Statement1,
Statement2,
Statement3
),
X,
Y
)
data:image/s3,"s3://crabby-images/2562a/2562ad8f2234fe14cd3f382ff028f9cd1923ba87" alt="Benjamin_Jones Benjamin_Jones"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 05, 2021 07:14 AM
@Alexey_Gusev Thanks, you were correct on the syntax.
However, even with this corrected the calculation does not work. I can return simple text strings, however can’t get it to perform calculation A if the and conditions are met, else B if not.
Ex:
IF(
AND(
{FY}=“22”,
{MM}=“10”
),
“A”,
“B”
)
^^this works
IF(
AND(
{FY}=“22”,
{MM}>=“10”
),
{Total Time} * {Rate by FY by MM}+{Pass through Materials},
{Direct Time} * {Rate by FY by MM}+{Pass through Materials}
)
^^ this does not.
- Can anyone confirm if it is possible to do conditional calculations?
- If not possible could i do the calculations in different fields and create a conditional to pull one of these values based on the parameters?
data:image/s3,"s3://crabby-images/2562a/2562ad8f2234fe14cd3f382ff028f9cd1923ba87" alt="Benjamin_Jones Benjamin_Jones"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 05, 2021 07:40 AM
And the answer is 1. no, 2. yes.
IF(
AND(
{FY}>=“22”,
{MM}>=“10”
),
{Post 10/2021},{Pre 10/2021})
data:image/s3,"s3://crabby-images/56681/566811218c571b16b48acc8ee7c884e1a2c9f943" alt="Justin_Barrett Justin_Barrett"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 05, 2021 09:04 AM
For numeric comparisons, the numbers that you’re comparing against should not be in quotes. Airtable will sometimes auto-convert strings to numbers for mathematical operations, but it’s not something that should be relied upon.
If {FY}
and {MM}
are numeric fields (i.e. fields that output numeric values), try this instead:
IF(
AND(
{FY} = 22,
{MM} >= 10
),
{Total Time} * {Rate by FY by MM} + {Pass through Materials},
{Direct Time} * {Rate by FY by MM} + {Pass through Materials}
)
If those fields output strings, use the VALUE()
function to convert them to numbers before comparison, like this:
IF(
AND(
VALUE({FY}) = 22,
VALUE({MM}) >= 10
),
{Total Time} * {Rate by FY by MM} + {Pass through Materials},
{Direct Time} * {Rate by FY by MM} + {Pass through Materials}
)
This could also be simplified a bit. Because all that you’re changing is the first operand in the “inner” formula—{Total Time}
vs {Direct Time}
—the overall formula could be written like this (using the second VALUE()
-driven version as an example):
IF(
AND(
VALUE({FY}) = 22,
VALUE({MM}) >= 10
),
{Total Time}, {Direct Time}
) * {Rate by FY by MM} + {Pass through Materials}
data:image/s3,"s3://crabby-images/8cb2f/8cb2f3bec7aa3b8b55da0b6eb8d1d81194430375" alt=""