计算两个日期相差几年几个月

简介:

 

public static class dateTimeDiff
{
    /// <summary>
    /// 计算日期间隔
    /// </summary>
    /// <param name="d1">要参与计算的其中一个日期字符串</param>
    /// <param name="d2">要参与计算的另一个日期字符串</param>
    /// <returns>一个表示日期间隔的TimeSpan类型</returns>
    public static TimeSpan toResult(string d1, string d2)
    {
        try
        {
            DateTime date1 = DateTime.Parse(d1);
            DateTime date2 = DateTime.Parse(d2);
            return toResult(date1, date2);
        }
        catch
        {
            throw new Exception("字符串参数不正确!");
        }
    }
    /// <summary>
    /// 计算日期间隔
    /// </summary>
    /// <param name="d1">要参与计算的其中一个日期</param>
    /// <param name="d2">要参与计算的另一个日期</param>
    /// <returns>一个表示日期间隔的TimeSpan类型</returns>
    public static TimeSpan toResult(DateTime d1, DateTime d2)
    {
        TimeSpan ts;
        if (d1 > d2)
        {
            ts = d1 - d2;
        }
        else
        {
            ts = d2 - d1;
        }
        return ts;
    }

    /// <summary>
    /// 计算日期间隔
    /// </summary>
    /// <param name="d1">要参与计算的其中一个日期字符串</param>
    /// <param name="d2">要参与计算的另一个日期字符串</param>
    /// <param name="drf">决定返回值形式的枚举</param>
    /// <returns>一个代表年月日的int数组,具体数组长度与枚举参数drf有关</returns>
    public static int[] toResult(string d1, string d2, diffFormat drf)
    {
        try
        {
            DateTime date1 = DateTime.Parse(d1);
            DateTime date2 = DateTime.Parse(d2);
            return toResult(date1, date2, drf);
        }
        catch
        {
            throw new Exception("字符串参数不正确!");
        }
    }
    /// <summary>
    /// 计算日期间隔
    /// </summary>
    /// <param name="d1">要参与计算的其中一个日期</param>
    /// <param name="d2">要参与计算的另一个日期</param>
    /// <param name="drf">决定返回值形式的枚举</param>
    /// <returns>一个代表年月日的int数组,具体数组长度与枚举参数drf有关</returns>
    public static int[] toResult(DateTime d1, DateTime d2, diffFormat drf)
    {
        #region 数据初始化
        DateTime max;
        DateTime min;
        int year;
        int month;
        int tempYear, tempMonth;
        if (d1 > d2)
        {
            max = d1;
            min = d2;
        }
        else
        {
            max = d2;
            min = d1;
        }
        tempYear = max.Year;
        tempMonth = max.Month;
        if (max.Month < min.Month)
        {
            tempYear--;
            tempMonth = tempMonth + 12;
        }
        year = tempYear - min.Year;
        month = tempMonth - min.Month;
        #endregion
        #region 按条件计算
        if (drf == diffFormat.Day)
        {
            TimeSpan ts = max - min;
            return new int[] { ts.Days };
        }
        if (drf == diffFormat.Month)
        {
            return new int[] { month + year * 12 };
        }
        if (drf == diffFormat.Year)
        {
            return new int[] { year };
        }
        return new int[] { year, month };
        #endregion
    }
}
/// <summary>
/// 关于返回值形式的枚举
/// </summary>
public enum diffFormat
{
    /// <summary>
    /// 年数和月数
    /// </summary>
    YearMonth,
    /// <summary>
    /// 年数
    /// </summary>
    Year,
    /// <summary>
    /// 月数
    /// </summary>
    Month,
    /// <summary>
    /// 天数
    /// </summary>
    Day,
}

 

例:
                DateTime dt1 = DateTime.Parse(dt.Rows[0]["mtime"].ToString());
                DateTime dt2 = DateTime.Parse(dt.Rows[count - 1]["mtime"].ToString());

                int[] kk = dateTimeDiff.toResult(dt1, dt2, diffFormat.Month);

 




本文转自94cool博客园博客,原文链接:http://www.cnblogs.com/94cool/archive/2011/06/13/2079795.html,如需转载请自行联系原作者


相关文章
|
10月前
计算LocalDate之间的天数差,方便快捷
计算LocalDate之间的天数差,方便快捷
225 0
【SQL开发实战技巧】系列(十七):数据仓库中时间类型操作(初级)确定两个日期之间的工作天数、计算—年中周内各日期出现次数、确定当前记录和下一条记录之间相差的天数
如何确定两个日期之间的工作日有多少天、计算—年中每周内各日期出现次数、确定当前记录和下一条记录之间相差的天数【SQL开发实战技巧】这一系列博主当作复习旧知识来进行写作,毕竟SQL开发在数据分析场景非常重要且基础,面试也会经常问SQL开发和调优经验,相信当我写完这一系列文章,也能再有所收获,未来面对SQL面试也能游刃有余~。本章节的三个需求:确定两个日期之间的工作天数、计算—年中周内各日期出现次数、确定当前记录和下一条记录之间相差的天数有些许难度,不过建议还是学会比较好。
【SQL开发实战技巧】系列(十七):数据仓库中时间类型操作(初级)确定两个日期之间的工作天数、计算—年中周内各日期出现次数、确定当前记录和下一条记录之间相差的天数
|
算法
计算在工作日时间推迟时间的算法
计算在工作日时间推迟时间的算法
146 0
计算在工作日时间推迟时间的算法
计算历史上某日为星期几
计算历史上某日为星期几
70 2
[Python]计算指定时间与当前时间相差几年几月几日
[Python]计算指定时间与当前时间相差几年几月几日
Qt 计算两个日前间隔天数
某一个大神写的 改写了一点 请无视注释
154 0
UTC世界标准时间转化为正常时间
一,UTC 协调世界时,又称世界统一时间、世界标准时间、国际协调时间。由于英文(CUT)和法文(TUC)的缩写不同,作为妥协,简称UTC。协调世界时是以原子时秒长为基础,在时刻上尽量接近于世界时的一种时间计量系统。
5305 0