0

Calculate final date work days

How can we calculate a final date only on working days (without weekends and holidays)?

today()+Duration

I tried to do a loop and check if it's weekend or vacation (with vacation table for p in select vacation_table), but the calculation is slow.

5 replies

null
    • Birger_H
    • 7 yrs ago
    • Reported - view

    This is the last working day of the current week:

    –––
    var myDay := today();
    let myWeek := week(today());
    while week(myDay) = myWeek do 
       myDay := myDay + 1
    end;
    myDay - 3
    –––

    Birger

    • Frank_Bohmer
    • 7 yrs ago
    • Reported - view

    Or this: date(year(today()), month(today()), day(today()) - weekday(today()) + 4)

    • Frank_Bohmer
    • 7 yrs ago
    • Reported - view

    weekday(Date) will be 0 for Monday to 6 for Sunday

    • Mconneen
    • 7 yrs ago
    • Reported - view

    I like to say that I often walk around the block to go next door...   There may be an easier way.. but this will calculate an end date given a start date and a DURATION in workdays .. it ignores holidays..  If you want to make it EFFORT based.. See the Use Case about calculating workdays accounting for holidays.. 

    let d := 7 - weekday('Start Date');
    let t := DURATION - d;
    let w := floor(t / 5);
    let r := t - 5 * w;
    let o := d + w * 7 + r + 1;
    date(year('Start Date'), month('Start Date'), day('Start Date') + o)

    • Mconneen
    • 7 yrs ago
    • Reported - view

    Well.. I guess if it was 

    let d := 6 - weekday('Start Date') .. 

    I would not have to add 1 back at the end.. :) 

Content aside

  • 7 yrs agoLast active
  • 5Replies
  • 2660Views