- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 03:36 AM
Hi! I want to add a formula that does the following:
If “created on” is within the last week OR “revisit on” is today, then TRUE (i.e. check a box or write true in a text field).
“Created on” and “revisit on” are both date fields.
This way, I can better filter my view (my filter includes both “and” and “or” conditions, which is why I need to use a formula).
Thank you!!
Solved! Go to Solution.
Accepted Solutions
data:image/s3,"s3://crabby-images/940e1/940e135223332b9d19b1ab1302c3183a406470b3" alt="kuovonne kuovonne"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 07:21 AM
Welcome to the community!
You may need to edit the field names so that they exactly match your field names. Otherwise Airtable will not accept the formula.
You also need to check to make sure that the created time is greater than 0, or future dates will trigger the “true” value.
IF(
OR(
AND(
DATETIME_DIFF(TODAY(), {created on}, 'days') <= 7,
DATETIME_DIFF(TODAY(), {created on}, 'days') >= 0
),
{revisit on} = TODAY()
),
"true"
)
Here are a couple of other cautions about formulas and date/time fields:
- The TODAY() formula is not updated continuously, you may need to reload a view in order to refresh the calculations.
- Values may end up off by a day, depending on what time zone you are in, how you have time zones configured, and when you view the data. Dealing with time zones can be a bit involved and usually requires a bit more information about the specific use case.
If this answers your problem, could you please mark this post as the solution?
If not, could you please give a bit more details on your use case and a screen capture?
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 03:44 AM
Here’s what I tried, but the formula isn’t formatted correctly:
IF(DATETIME_DIFF({CREATED_TIME}, TODAY, ‘days’) < 7 OR({Revisit on}=TODAY), “True”, “False”)
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 06:55 AM
Hi @Joshi_Gottlieb - when you do an “OR” the format isn’t:
Condition A OR Condition B
but:
OR(Condition A, Condition B)
So you’ll end up with something like:
IF(OR(Condition A, Condition B), 'True', 'False')
JB
(If this answers your question please mark it as “Solution” - if not, please post again. Thanks!)
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 07:10 AM
Thank you for your reply!
Somehow I’m still getting the formatting wrong - Airtable won’t accept this formula:
IF(OR(DATETIME_DIFF({CREATED_TIME}, TODAY, ‘days’) < 7, ({Revisit on}=TODAY)), ‘True’, ‘False’)
data:image/s3,"s3://crabby-images/940e1/940e135223332b9d19b1ab1302c3183a406470b3" alt="kuovonne kuovonne"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 07:21 AM
Welcome to the community!
You may need to edit the field names so that they exactly match your field names. Otherwise Airtable will not accept the formula.
You also need to check to make sure that the created time is greater than 0, or future dates will trigger the “true” value.
IF(
OR(
AND(
DATETIME_DIFF(TODAY(), {created on}, 'days') <= 7,
DATETIME_DIFF(TODAY(), {created on}, 'days') >= 0
),
{revisit on} = TODAY()
),
"true"
)
Here are a couple of other cautions about formulas and date/time fields:
- The TODAY() formula is not updated continuously, you may need to reload a view in order to refresh the calculations.
- Values may end up off by a day, depending on what time zone you are in, how you have time zones configured, and when you view the data. Dealing with time zones can be a bit involved and usually requires a bit more information about the specific use case.
If this answers your problem, could you please mark this post as the solution?
If not, could you please give a bit more details on your use case and a screen capture?
data:image/s3,"s3://crabby-images/940e1/940e135223332b9d19b1ab1302c3183a406470b3" alt="kuovonne kuovonne"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 07:32 AM
Your formula was mostly correct, except for your use of the TODAY()
function. You need to have the parentheses as part of the function call. Otherwise, Airtable thinks that you are looking for a field named TODAY
, which you do not have.
If this answers your problem, please mark this post as the solution. Otherwise, could you please give a bit more details and a screen capture?
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 07:38 AM
Thank you so much, this formula works – thanks also for telling me where I went wrong.
Do you know why the second record doesn’t return “true”? Since it should return “true” if it was created within the last week or if the “Revisit on” date is today:
Thanks again :slightly_smiling_face:
data:image/s3,"s3://crabby-images/940e1/940e135223332b9d19b1ab1302c3183a406470b3" alt="kuovonne kuovonne"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 07:42 AM
Good catch. You need to check if the created on date is greater than or equal to the TODAY, not just greater than. I edited my original formula with the fix.
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
May 25, 2020 07:46 AM
This works, thank you sooo much!
data:image/s3,"s3://crabby-images/79abb/79abbc03cc624ea7bc441501b499dd398789db84" alt=""