zoukankan      html  css  js  c++  java
  • C# 之DateDiff 时间差扩展方法

    序言:
    在对分析数据进行统计时,又一次遇到需要计算时间差值的问题,所以特在此记录。该方法和SQL Server中的DateDiff方法类似,主要根据传入的时间格式,开始时间,结束时间,来返回需要的时间差。

         //时间格式枚举
        public enum DateInterval
        {
            Second, Minute, Hour, Day, Week, Month, Quarter, Year
        }
    
        public sealed class DateTimeExtension
        {
            public DateTimeExtension()
            {
            }
            /*
            interval 必要。字符串表达式,表示用来计算date1 和 date2 的时间差的时间间隔
            Date1□date2 必要;Variant (Date)。计算中要用到的两个日期。
            Firstdayofweek 可选。指定一个星期的第一天的常数。如果未予指定,则以星期日为第一天。
            firstweekofyear 可选。指定一年的第一周的常数。如果未予指定,则以包含 1 月 1 日的星期为第一周。
             */
            public static long DateDiff(DateInterval Interval, System.DateTime  StartDate, System.DateTime EndDate)
            {
                long lngDateDiffValue = 0;
                System.TimeSpan TS = new System.TimeSpan(EndDate.Ticks -  StartDate.Ticks);
                switch (Interval)
                {
                    case DateInterval.Second:
                        lngDateDiffValue = (long)TS.TotalSeconds;
                        break;
                    case DateInterval.Minute:
                        lngDateDiffValue = (long)TS.TotalMinutes;
                        break;
                    case DateInterval.Hour:
                        lngDateDiffValue = (long)TS.TotalHours;
                        break;
                    case DateInterval.Day:
                        lngDateDiffValue = (long)TS.Days;
                        break;
                    case DateInterval.Week:
                        lngDateDiffValue = (long)(TS.Days / 7);
                        break;
                    case DateInterval.Month:
                        lngDateDiffValue = (long)(TS.Days / 30);
                        break;
                    case DateInterval.Quarter:
                        lngDateDiffValue = (long)((TS.Days / 30) / 3);
                        break;
                    case DateInterval.Year:
                        lngDateDiffValue = (long)(TS.Days / 365);
                        break;
                }
                return (lngDateDiffValue);
            }//end of DateDiff
        }
       
    
  • 相关阅读:
    升级visual studio 2010中的jquery1.4.2
    windows 自动登录
    clipse3.2/3.3中指定第三方包(JAR)和类路径(CLASSPATH)的几个方法(转做笔记)
    MyEclips 配置文章集合
    JNDI全攻略(二)
    JNDI全攻略(一)
    Eclipse中webinf和metainf文件夹的信息
    MYECLIPSE7.5中安装SVN几步轻松实现
    天风网上商店系统 Beta (源码)
    SQL server 2005中无法新建作业(Job)的问题
  • 原文地址:https://www.cnblogs.com/jerque/p/15011923.html
Copyright © 2011-2022 走看看