How to check for holidays in loop and populate date before holiday date.
- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Mute
- Printer Friendly Page
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Notify Moderator
I have below holiday list. In new column I want to populate date (Holiday-1) if holiday date match with current date. if there is consecutive days in holiday list then populate date( holiday start date-1) and if holiday on Monday populate Friday date which will be holiday-2.
Holiday
2024-01-01
2024-01-26
2024-03-29
2024-04-01
2024-04-25
2024-12-25
2024-12-26
2024-07-24
2024-07-23
2024-07-22
Solved! Go to Solution.
- Labels:
- Workflow
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Notify Moderator
Hi there,
See attached. I added the dates into different groups based on whether or not they are consecutive and then applied the logic based on the min date from that group.
I wasn't sure if you just wanted to apply to the whole table or only apply the shift if the date "match[es] with current date" (as stated in the question). If you did intend for this, just add a IF datetimetoday() = [Holiday] ELSE around the formula.
Also, not sure if it'll happen, but you might want to add logic for if the holiday ever falls on the weekend.
Hope that helps!
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Notify Moderator
Thanks Lindon for your quick response. I want to apply shift if current date matches with Holiday. Also, I need to consider Friday and Monday holiday under consecutive group. How can I do that for i.e 19 July and 22 July is holiday in the provided list. So shift date should have 18 July So 19-24 july should come under group 6.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Notify Moderator
Here is a variation on @LindonB 's workflow that groups consecutive holidays across weekends. This workflow is dynamic, based on the holidays used as input, but you can just as easily adapt this to pre-calculate what date each holiday should map to and then you will only need to handle
Happy Solving!
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Notify Moderator
For the first (wanting to only apply the shift if the current date = holiday), you can either add a filter at the start to check:
DATETIMETODAY()=[Holiday]
The will lead to the final output/browse only containing the shifted date for today.
Otherwise, if you want to return the full dataset but only shift dates when current date = holiday, then adjust the formula in the workflow to be....
If DateTimeToday()!=[Holiday] THEN [Holiday]
ELSEIF DateTimeFormat([Min Eligible Date],'%A')='Monday' THEN DateTimeAdd([Min Eligible Date],-3,'days')
ELSE DateTimeAdd([Min Eligible Date],-1,'days') ENDIF
Since today is not in the Holiday list, the results will be the same as the original data in this case.
For the second, I believe the workflow is doing this. It will find the groupings based on consecutive days (July 22-24). Then it looks at the minimum in that group (July 22). Then it returns the prior Friday if the min in a Monday or the last day otherwise. (Note that July 19 wasn't listed in your data, but the rest would by July 18 if it was.) Again, I might build in more logic for weekends, and Friday holidays currently don't have any extra logic.
Does that help or is there a step I'm misunderstanding?
Cheers!
