Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17


C# number of workdays

Posted on 2009-05-12
Medium Priority
Last Modified: 2012-05-06

I would like to get number of working days in current month and year until today (C#).

e.g.: today is 12.5.2009 -->  8 working days
tomorrow it will be 13.5.2009 --> 9 working days

Thank you.
Question by:SimpleJ
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 2

Assisted Solution

crystal_tower earned 400 total points
ID: 24363026
You need to count days without free ones, basic version:
- count all days without weekends, like:
DateTime theDateFrom;
DateTime theDateTo;
if(theDateFrom.DayOfWeek != DayOfWeek.Saturday && theDateFrom.DayOfWeek != DayOfWeek.Sunday)
count till theDateFrom <= theDateTo

- however remember about bank holidays. Look for instance:

- finally, all depends on calendar. Saturday or Sunday could be a working day.

LVL 39

Expert Comment

ID: 24363044
In http:Q_24377674.html I explained this process for VB, but that's the other way around (given the number of business days, how many "normal" days would that be?).
LVL 39

Accepted Solution

abel earned 1600 total points
ID: 24363089

try again that link: http://Q_24377674.html

anyway, crystal_tower gave the same idea. Here's how I did it (full loop):
private int GetBusinessDays(DateTime dateFrom, DateTime dateTo)
    int countDays = 0;
    while (dateFrom < dateTo) {
        dateFrom = dateFrom.AddDays(1);
        DayOfWeek weekDay = dateFrom.DayOfWeek;
        if (weekDay != DayOfWeek.Saturday & weekDay != DayOfWeek.Sunday)  
             countDays += 1;
    return countDays;

Open in new window

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

LVL 39

Expert Comment

ID: 24363095
something wrong with my pasting of links at EE... Sorry about the clutter. Last time:

Author Comment

ID: 24363544
Thank you
LVL 39

Expert Comment

ID: 24363631
> I used abel s method.

nice and tx. You accidentally hit the "Accept and Award Point" of your own comment (which effectively makes your comment the solution, which it isn't), instead, I believe you wanted to assign points to me and crystal_tower. You can do so by clicking the "Accept Multiple Solutions". See screenshot for the difference between the two.

Note that the first one (the one in red) is only considered good if you found the solution yourself. Also see closing questions.

LVL 39

Expert Comment

ID: 24363646
objection reviewers: see comment http:#24363631

Author Comment

ID: 24363717
Thanks for the info.


Featured Post

Important Lessons on Recovering from Petya

In their most recent webinar, Skyport Systems explores ways to isolate and protect critical databases to keep the core of your company safe from harm.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

We all know that functional code is the leg that any good program stands on when it comes right down to it, however, if your program lacks a good user interface your product may not have the appeal needed to keep your customers happy. This issue can…
Performance in games development is paramount: every microsecond counts to be able to do everything in less than 33ms (aiming at 16ms). C# foreach statement is one of the worst performance killers, and here I explain why.
The viewer will learn how to use the return statement in functions in C++. The video will also teach the user how to pass data to a function and have the function return data back for further processing.
The viewer will be introduced to the member functions push_back and pop_back of the vector class. The video will teach the difference between the two as well as how to use each one along with its functionality.

705 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question