Solved

C# number of workdays

Posted on 2009-05-12
8
1,095 Views
Last Modified: 2012-05-06
Hello.

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.
0
Comment
Question by:SimpleJ
[X]
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
8 Comments
 
LVL 3

Assisted Solution

by:crystal_tower
crystal_tower earned 100 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)
   workdays++;
count till theDateFrom <= theDateTo

- however remember about bank holidays. Look for instance:
http://www.codeproject.com/KB/dotnet/HolidayCalculator.aspx

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

0
 
LVL 39

Expert Comment

by:abel
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?).
0
 
LVL 39

Accepted Solution

by:
abel earned 400 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

0
PeopleSoft Has Never Been Easier

PeopleSoft Adoption Made Smooth & Simple!

On-The-Job Training Is made Intuitive & Easy With WalkMe's On-Screen Guidance Tool.  Claim Your Free WalkMe Account Now

 
LVL 39

Expert Comment

by:abel
ID: 24363095
something wrong with my pasting of links at EE... Sorry about the clutter. Last time: http://www.experts-exchange.com/Programming/Languages/.NET/Visual_Basic.NET/Q_24377674.html
0
 
LVL 1

Author Comment

by:SimpleJ
ID: 24363544
Thank you
0
 
LVL 39

Expert Comment

by:abel
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.

ScreenShot270.png
0
 
LVL 39

Expert Comment

by:abel
ID: 24363646
objection reviewers: see comment http:#24363631
0
 
LVL 1

Author Comment

by:SimpleJ
ID: 24363717
Thanks for the info.

0

Featured Post

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

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…
Calculating holidays and working days is a function that is often needed yet it is not one found within the Framework. This article presents one approach to building a working-day calculator for use in .NET.
The viewer will learn how to user default arguments when defining functions. This method of defining functions will be contrasted with the non-default-argument of defining functions.
The viewer will learn additional member functions of the vector class. Specifically, the capacity and swap member functions will be introduced.

751 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