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