已知时间日期得到星期

算法如下:
基姆拉尔森计算公式
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 IntegerAs 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 / 400Mod 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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值