Return the previous or next business day 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 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) &amp;&amp; (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 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 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) &amp;&amp; (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;
      }
    }
    }
}

   
     


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) &amp;&amp; (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) &amp;&amp; (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;
      }
    }    
    }
}

   
     


Screen for holidays

   
 
// 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>
    /// 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) &amp;&amp; (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;
      }
    }
    /// <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) &amp;&amp; (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);
    }
   }
}

   
     


Return a elapsed time in formatted string. (hh:mm:ss:mi)

   
 

// 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 a elapsed time in formatted string. (hh:mm:ss:mi)
    /// </summary>
    /// <param name="ticks"></param>
    /// <returns></returns>
    public static string ElapsedTime(long ticks)
    {
      TimeSpan ts = new TimeSpan(ticks);

      return String.Format("{0}:{1}:{2}:{3}",
        ts.Hours,
        ts.Minutes,
        ts.Seconds,
        ts.Milliseconds
      );
    }

    /// <summary>
    /// return a elapsed time in formatted string. (hh:mm:ss:mi)
    /// </summary>
    /// <param name="t1"></param>
    /// <returns></returns>
    public static string ElapsedTime(DateTime t1)
    {
      return ElapsedTime(t1, DateTime.Now);
    }

    /// <summary>
    /// return a elapsed time in formatted string. (hh:mm:ss:mi)
    /// </summary>
    /// <param name="t1"></param>
    /// <param name="t2"></param>
    /// <returns></returns>
    public static string ElapsedTime(DateTime t1, DateTime t2)
    {
      if (t2 > t1)
        return ElapsedTime(t2.Ticks - t1.Ticks);
      else
        return ElapsedTime(t1.Ticks - t2.Ticks);
    }
   }
}

   
     


Return a unique identifier based on system's full date (yyyymmdd) and time (hhmissms).

   
 

// 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 a unique identifier based on system&#039;s full date (yyyymmdd) and time (hhmissms).
    /// 
    /// Output sample: 2006040212445099
    /// </summary>
    public static string UniqueID
    {
      get
      {
        DateTime date = DateTime.Now;

        string uniqueID = String.Format(
          "{0:0000}{1:00}{2:00}{3:00}{4:00}{5:00}{6:000}",
          date.Year, date.Month, date.Day,
          date.Hour, date.Minute, date.Second, date.Millisecond
          );
        return uniqueID;
      }
    }
   }
}

   
     


Gets the months between.

   
 
using System;
public class MainClass{
        /// <summary>
        /// Gets the days between.
        /// </summary>
        /// <param name="first">The first.</param>
        /// <param name="last">The last.</param>
        /// <param name="inclusive">if set to <c>true</c> [inclusive].</param>
        /// <returns></returns>
        public static int GetDaysBetween(DateTime first, DateTime last, bool inclusive)
        {
            TimeSpan span = last - first;

            return inclusive ? span.Days + 1 : span.Days;
        }
        /// <summary>
        /// Gets the months between.
        /// </summary>
        /// <param name="first">The first.</param>
        /// <param name="last">The last.</param>
        /// <param name="inclusive">if set to <c>true</c> [inclusive].</param>
        /// <returns></returns>
        public static int GetMonthsBetween(DateTime first, DateTime last, bool inclusive)
        {
            int result = GetDaysBetween(first, last, true) / 30;
            return inclusive ? result + 1 : result;
        }
}

   
     


Gets the end of year.

   
 
using System;
public class MainClass{
        /// <summary>
        /// Gets the end of year.
        /// </summary>
        /// <param name="date">The date.</param>
        /// <returns></returns>
        public static DateTime GetEndOfYear(DateTime date)
        {
            return new DateTime(new DateTime(date.Year + 1, 1, 1).Ticks - 1);
        }
}