计算两个日期间的工作日

2016-02-19 16:30 16 1 收藏

在这个颜值当道,屌丝闪边的时代,拼不过颜值拼内涵,只有知识丰富才能提升一个人的内在气质和修养,所谓人丑就要多学习,今天图老师给大家分享计算两个日期间的工作日,希望可以对大家能有小小的帮助。

【 tulaoshi.com - 编程语言 】

本示例的功能是如何计算给定的两个日期之间的工作日,你可以选择是否将星期六或星期日也包括进去。同时本程序还允许你可入一些假期,从而在计算时将这些假期排除在外。
  
  函数:
  
  PublicFunctionBusinessDateDiff(ByValdDate1AsDate,ByValdDate2AsDate)AsLong
  
  该函数的功能是计算两个日期(dDate1和dDate2)之间的工作日。下面的这些属性允许你对计算实施控制,告诉程序如何进行计算。
  
  属性
  
  PublicIncludeSaturdaysAsBoolean
  
  当值为真,计算时将包括星期六,否则将星期六排除在外。
  
  PublicIncludeSundaysAsBoolean
  
  当值为真,计算时将包括星期日,否则将星期日排除在外。
  
  PublicPropertyLetIncludeFirstDate(bIncAsBoolean)PublicProperty
  GetIncludeFirstDate()AsBoolean
  
  在默认情况下,BusinessDateDiff函数会将你输入的起始日包括在计算中,但不包括你输入的终止日。将该属性值设为假,计算时就不包括你输入的起始日。
  
  PublicPropertyLetIncludeLastDate(bIncAsBoolean)

PublicPropertyGetIncludeLastDate()AsBoolean
  
  在默认情况下,BusinessDateDiff函数不包括你输入的最后一天。将该属性值设为真,程序把你输入的最后一天包括在计算中。
  
  方法
  
  PublicSubHolidayAdd(dHolidayAsDate)
  
  添加一个假期列表,以便在计算时排除这些假期。在默认情况下,没有添加任何假期。
  
  PublicSubHolidayRemove(dHolidayAsDate)
  
  从假期列表移除假期
  
  PublicSubHolidayClear()
  
  清除全部假期列表
  
  代码清单
  
  首先建立一个新的类模块,名为cBusinessDates,将下面的代码粘贴进去。
  
  OptionExplicit
  
  PublicIncludeSaturdaysAsBoolean
  PublicIncludeSundaysAsBoolean
  
  PrivatembIncludeFirstDateAsBoolean
  PrivatembIncludeLastDateAsBoolean
  
  PrivateHolidaysAsNewCollection
  
  PublicSubHolidayAdd(dHolidayAsDate)
  
  OnErrorResumeNext
  
  Holidays.AdddHoliday,"D"&dHoliday
  
  IfErrThen
  Err.Clear
  EndIf
  
  EndSub
  
  PublicSubHolidayRemove(dHolidayAsDate)
  
  OnErrorResumeNext
  
  Holidays.Remove"D"&dHoliday
  
  IfErrThen
  Err.Clear
  EndIf
  
  EndSub
  
  PublicSubHolidayClear()
  
  DimxAsLong
  
  Forx=1ToHolidays.Count
  Holidays.Remove1
  Next
  
  EndSub
  
  PublicPropertyLetIncludeFirstDate(bIncAsBoolean)
  
  mbIncludeFirstDate=bInc
  
  EndProperty
  
  PublicPropertyLetIncludeLastDate(bIncAsBoolean)
  
  mbIncludeLastDate=bInc
  
  EndProperty
  
  PublicPropertyGetIncludeFirstDate()AsBoolean
  
  IncludeFirstDate=mbIncludeFirstDate
  
  EndProperty
  
  PublicPropertyGetIncludeLastDate()AsBoolean
  
  IncludeLastDate=mbIncludeLastDate
  
  EndProperty
  
  '该函数不把dDate2包含在计算中,如果dDate2是星期日,而你又选择了计算星期日,该日期仍不计算在内。
  
  PublicFunctionBusinessDateDiff(ByValdDate1AsDate,ByValdDate2AsDate)AsLong
  
  DimdCurDateAsDate
  DimdLastDateAsDate
  DimdFirstDateAsDate
  DimlDayCountAsLong
  DimeDayAsVbDayOfWeek
  DimdHolidayAsVariant
  
  '调整应将哪一个日期包括在计算中(第一个还是第二个)
  
  IfIncludeFirstDateThen
  dFirstDate=dDate1
  Else
  dFirstDate=dDate1 1
  EndIf
  
  IfIncludeLastDateThen
  dLastDate=dDate2 1
  Else
  dLastDate=dDate2
  EndIf
  
  '在所有日期中循环,并更新日期计数
  
  dCurDate=dFirstDate
  
  DoWhiledCurDatedLastDate
  
  eDay=WeekDay(dCurDate)
  
  IfIncludeSaturdaysAndeDay=vbSaturdayThen
  lDayCount=lDayCount 1
  EndIf
  
  IfIncludeSundaysAndeDay=vbSundayThen
  lDayCount=lDayCount 1
  EndIf
  
  IfeDay=vbMondayAndeDay=vbFridayThen
  lDayCount=lDayCount 1
  EndIf
  
  dCurDate=dCurDate 1
  
  Loop
  
  '根据假期调整日期计数
  
  ForEachdHolidayInHolidays
  
  '如果假期在你所输入的日期范围之内
  
  IfCDate(dHoliday)=dFirstDateAndCDate(dHoliday)=dLastDateThen
  
  eDay=WeekDay(CDate(dHoliday))
  
  IfIncludeSaturdaysAndeDay=vbSaturdayThen
  lDayCount=lDayCount-1
  EndIf
  
  IfIncludeSundaysAndeDay=vbSundayThen
  lDayCount=lDayCount-1
  EndIf
  
  IfeDay=vbMondayAndeDay=vbFridayThen
  lDayCount=lDayCount-1
  EndIf
  
  EndIf
  
  Next
  
  BusinessDateDiff=lDayCount
  
  EndFunction
  
  PrivateSubClass_Initialize()
  
  IncludeFirstDate=True
  IncludeLastDate=False
  IncludeSundays=False
  IncludeSaturdays=False
  
  EndSub

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)->

来源:http://www.tulaoshi.com/n/20160219/1612324.html

延伸阅读
标签: PHP
  //在PHP中处理日期非常不方便,比如求两个日期之间相差的月份?该怎么办呢?  //文件名:date.inc.php3  //在使用这两个函数前,要先将日期或日期时间转换成timestamp类型。  //如:  //$today=mktime(0,0,0,date("m"),date("d"),date("Y"));  /****模拟sqlserver中的dateadd...
下面图老师小编教大家两个瑜伽动作可以有效的缓解工作压力的呦 1、脊柱转动式 坐姿,两腿并拢向前伸直。 吸气,将一侧腿收回,脚掌放在另一侧膝盖外的地面上。手扶脚踝。保持脊柱自然伸展。 呼气,另一侧手轻扶臀部后侧地面,略微推动,使脊柱向后拧转。眼睛尽量看向身体后侧,控制姿势...
标签: 营养价值
我们中国是个地大物博的国家,同时也是一个人口大国。通常会因为地域和民族的差异,而导致风俗习惯的不同。风俗习惯的不同经常表现在穿着和饮食方面,比如我们汉族人穿着的特点和其他族都是不一样的;同时我们吃的东西也和其他族的人吃的食物有着很大的差异。 我们的饮食差异最好的表现就是在于春节了,有的地方会吃饺子,而有的地方...
两个世界2 运行序列号 进入游戏后提示输入序列号,可用下面一组: JR2W-FY5U-R34N-YZU4 更多相关内容请关注:两个世界2专区 两个世界2 2小时游玩评价 玩了2个小时~谈谈自己的...
标签: 故事
故事两个朋友 在南非的莫诺莫塔帕王国,有两个真心的朋友,他们有福同享,有难同当。据说这里的人交朋友,比其他地方的人真心实意得多。一天夜里,人们早已进入了梦乡,一个朋友突然从睡梦中惊醒,一骨碌从床上爬起来就径直朝另一个朋友家跑来,把他家仆人叫醒,因为他感觉梦神已迈进了朋友家的大门。被吵醒的朋友非常惊慌,他穿起衣服,系好...

经验教程

912

收藏

9
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部