已知时间日期得到星期

算法如下:
基姆拉尔森计算公式
W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7
  在公式中d表示日期中的日数,m表示月份数,y表示年数。

注意:在公式中有个与其他公式不同的地方:

 把一月和二月看成是上一年的十三月和十四月,例:如果是2004-1-10则换算成:2003-13-10来代入公式计算。

代码如下:
 //y-年,m-月,d-日期


Function  CaculateWeekDay(y  As   Integer , m  As   Integer , d  As   Integer As   String
   
If  m  =   1   Then
      m 
=   13
   
End   If
   
If  m  =   2   Then
      m 
=   14
   
End   If
   
Dim  week  As   Integer   =  (d  +   2   *  m  +   3   * (m  +   1 /   5   +  y  +  y  /   4   -  y  /   100   +  y  /   400 Mod   7
   
Dim  weekstr  As   String   =   ""
   
Select   Case  week
      
Case   1
         weekstr 
=   " 星期一 "
      
Case   2
         weekstr 
=   " 星期二 "
      
Case   3
         weekstr 
=   " 星期三 "
      
Case   4
         weekstr 
=   " 星期四 "
      
Case   5
         weekstr 
=   " 星期五 "
      
Case   6
         weekstr 
=   " 星期六 "
      
Case   7
         weekstr 
=   " 星期日 "
   
End   Select
   
   
Return  weekstr
End Function   ' CaculateWeekDay

转载于:https://www.cnblogs.com/LCX/archive/2007/04/20/721123.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值