电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 站长之家-> SEO网站优化
计算两个日期间的工作日_visualbasic教程
作者:网友供稿 点击:0
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
本示例的功能是如何计算给定的两个日期之间的工作日,你可以选择是否将星期六或星期日也包括进去。同时本程序还允许你可入一些假期,从而在计算时将这些假期排除在外。

函数:

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

DoWhiledCurDate<>dLastDate

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.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·进军搜索引擎优化需要具备什么条件?_seo网站优化
·google的左手:近距离观察seo_seo网站优化
·分析:google的左手--近距离观察seo_seo网站优化
·搜索引擎优化(seo)方法和排名技巧_seo网站优化
·hao123的迷思--谈谈seo_seo网站优化
·百度排名no.1是怎样seo成功的_seo网站优化
·seo问题集2-搜索引擎优化_seo网站优化
·hao123的迷思:网址类网站与seo的关系1_seo网站优化
·hao123的迷思:网址类网站与seo的关系2_seo网站优化
·seo半小时速成笔记_seo网站优化

最新文章
·关于seo最佳的实践方法_seo网站优化
·seo中十大影响链接权重的因素浅析_seo网站优化
·seo新手教程:title的写法_seo网站优化
·seo:刚入门还不如不入门的_seo网站优化
·google补充材料没消失,内链优化很重要_seo网站优化
·献给想我一样初基础网站优化的朋友们_seo网站优化
·田锋林:seo博客细节调整_seo网站优化
·seo策略之大型网站_seo网站优化
·对网站做一些简单的seo处理_seo网站优化
·如何做到seo与网站的可读性共赢_seo网站优化


 
 


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号