Return the previous business date of the date specified. : Date Time Util « Date Time « C# / C Sharp






Return the previous business date of the date specified.

   
// crudwork
// Copyright 2004 by Steve T. Pham (http://www.crudwork.com)
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with This program.  If not, see <http://www.gnu.org/licenses/>.

using System;
using System.Collections.Generic;
using System.Text;

namespace crudwork.Utilities
{
  /// <summary>
  /// Date Utility
  /// </summary>
  public class DateUtil
  {
    /// <summary>
    /// return the previous business date of the date specified.
    /// </summary>
    /// <param name="today"></param>
    /// <returns></returns>
    public static DateTime PreviousBusinessDay(DateTime today)
    {
      DateTime result;
      switch (today.DayOfWeek)
      {
        case DayOfWeek.Sunday:
          result = today.AddDays(-2);
          break;

        case DayOfWeek.Monday:
          result = today.AddDays(-3);
          break;

        case DayOfWeek.Tuesday:
        case DayOfWeek.Wednesday:
        case DayOfWeek.Thursday:
        case DayOfWeek.Friday:
          result = today.AddDays(-1);
          break;

        case DayOfWeek.Saturday:
          result = today.AddDays(-1);
          break;

        default:
          throw new ArgumentOutOfRangeException("DayOfWeek=" + today.DayOfWeek);
      }
      return ScreenHolidays(result, -1);
    }
    /// <summary>
    /// Return the previous or next business day of the date specified.
    /// </summary>
    /// <param name="today"></param>
    /// <param name="addValue"></param>
    /// <returns></returns>
    public static DateTime GetBusinessDay(DateTime today, int addValue)
    {
      #region Sanity Checks
      if ((addValue != -1) && (addValue != 1))
        throw new ArgumentOutOfRangeException("addValue must be -1 or 1");
      #endregion

      if (addValue > 0)
        return NextBusinessDay(today);
      else
        return DateUtil.PreviousBusinessDay(today);
    }



    /// <summary>
    /// return the next business date of the date specified.
    /// </summary>
    /// <param name="today"></param>
    /// <returns></returns>
    public static DateTime NextBusinessDay(DateTime today)
    {
      DateTime result;
      switch (today.DayOfWeek)
      {
        case DayOfWeek.Sunday:
        case DayOfWeek.Monday:
        case DayOfWeek.Tuesday:
        case DayOfWeek.Wednesday:
        case DayOfWeek.Thursday:
          result = today.AddDays(1);
          break;

        case DayOfWeek.Friday:
          result = today.AddDays(3);
          break;

        case DayOfWeek.Saturday:
          result = today.AddDays(2);
          break;

        default:
          throw new ArgumentOutOfRangeException("DayOfWeek=" + today.DayOfWeek);
      }
      return ScreenHolidays(result, 1);
    }


    /// <summary>
    /// return the mm/dd string of the date specified.
    /// </summary>
    /// <param name="time"></param>
    /// <returns></returns>
    public static string MonthDay(DateTime time)
    {
      return String.Format("{0:00}/{1:00}", time.Month, time.Day);
    }

    /// <summary>
    /// screen for holidays 
    /// (simple mode)
    /// </summary>
    /// <param name="result"></param>
    /// <param name="addValue"></param>
    /// <returns></returns>
    public static DateTime ScreenHolidays(DateTime result, int addValue)
    {
      #region Sanity Checks
      if ((addValue != -1) && (addValue != 1))
        throw new ArgumentOutOfRangeException("addValue must be -1 or 1");
      #endregion

      // holidays on fixed date
      switch (MonthDay(result))
      {
        case "01/01":  // Happy New Year
        case "07/04":  // Independent Day
        case "12/25":  // Christmas
          return GetBusinessDay(result, addValue);
        default:
          return result;
      }
    }    
    }
}

   
    
    
  








Related examples in the same category

1.Gets the days between.
2.Return a unique identifier based on system's full date (yyyymmdd) and time (hhmissms).
3.Return a elapsed time in formatted string. (hh:mm:ss:mi)
4.Screen for holidays
5.Return the previous or next business day of the date specified.
6.Return true if the number of seconds has elapsed since the last check
7.Add Business Days
8.Get Day Of Week
9.Add week to a DateTime
10.Get the quarter number for the DateTime
11.Get the week number
12.Date and time To Words
13.Return the number of milliseconds since the Unix epoch (1 Jan., 1970 UTC) for a given DateTime value.
14.Convert Unix Seconds
15.Get Elapsed Time
16.Is given DateTime Weekend
17.Converts a Date to a string using relative time.
18.Gets the date from Year integer
19.Gets the date from Year and Month integer
20.Gets the date from Year, Month and Day integer
21.Gets the days in month.
22.Gets the days in year.
23.Gets the end of day.
24.Gets the end of week.
25.Gets the start of month.
26.Gets the end of month.
27.Gets the end of quarter.
28.Gets the end of year.
29.Gets the months between.
30.Date Time To String
31.Update text within a file by replacing a substring within the file.
32.Get Date Difference in String
33.Converts the specified date and time strings to their DateTime equivalent representation.
34.Create Expires In String
35.Compares 2 dates ignoring the milliseconds
36.Calculate date, based on specified time and unit
37.Gets the ordinal suffix for a given date
38.Generate the timestamp of the provided DateTime
39.Converts the date to start from midnight.
40.Converts the date to end at midnight.
41.Convert time from seconds to ticks
42.Generate the UNIX style timestamp for DateTime.UtcNow
43.Parse DateTime from "2011/5/2 14:40"