Wie ermittelt man die Kalenderwoche eines beliebigen Datums? Nach ein bisschen Stöbern in der Online-Hilfe sollte dies mit der DatePart-Funktion kein Problem sein: Dim nWeek As Integer nWeek = DatePart(DateInterval.WeekOfYear, vDate, _ FirstDayOfWeek.Monday, FirstWeekOfYear.FirstFourDays) Zunächst glaubt man, dass die Kalenderwoche auch korrekt ermittelt wird: ' Beispiel: 22.03.04 Dim nWeek As Integer nWeek = DatePart(DateInterval.WeekOfYear, New Date(2004, 3, 22), _ FirstDayOfWeek.Monday, FirstWeekOfYear.FirstFourDays) MsgBox(nWeek) ' Ergebnis: 13 - KORREKT! ' Beispiel: 31.12.07 nWeek = DatePart(DateInterval.WeekOfYear, New Date(2007, 12, 31), _ FirstDayOfWeek.Monday, FirstWeekOfYear.FirstFourDays) MsgBox(nWeek) ' Ergebnis: 53 - FALSCH! Korrekt wäre 1 (Jahr 2008)!!! ' Beispiel: 29.12.03 nWeek = DatePart(DateInterval.WeekOfYear, New Date(2003, 12, 29), _ FirstDayOfWeek.Monday, FirstWeekOfYear.FirstFourDays) MsgBox(nWeek) ' Ergebnis: 53 - FALSCH! Korrekt wäre 1 (Jahr 2004)!!! Fazit: Nachfolgender Tipp errechnet die Kalenderwoche auch dann korrekt, wenn es sich um die letzte Woche eines Kalenderjahres handelt. Public Function DateToWeek(ByVal dDate As Date) As String ' Startdatum der ersten Kalenderwoche des Jahres und Folgejahres berechnen Dim dThisYear As Date = CalendarWeek(1, dDate.Year) Dim dNextYear As Date = CalendarWeek(1, dDate.Year + 1) ' Prüfen, ob Datum zur ersten Woche des Folgejahres gehört If dDate >= dNextYear Then ' Rückgabe: KW 1 des Folgejahres Return dDate.Year + 1 & "01" ElseIf dDate < dThisYear Then ' Falls das Datum noch zu einer KW aus dem letzten Jahr zählt Return dDate.Year - 1 & DatePart(DateInterval.WeekOfYear, _ New Date(dDate.Year - 1, 12, 28), FirstDayOfWeek.Monday, _ FirstWeekOfYear.FirstFourDays) Else ' KW = Differenz zum ersten Tag der ersten Woche Return dDate.Year & Format$(dDate.Subtract(dThisYear).Days \ 7 + 1, "00") End If End Function Die Funktion "CalendarWeek" finden Sie hier: Beispiel: ' Beispiel: 31.12.07 Dim sKW As String = DateToWeek(CDate("31.12.07")) ' Ergebnis: 01/2008 - KORREKT! MsgBox(sKW.Substring(4, 2) & "/" & sKW.Substring(0, 4)) Dieser Tipp wurde bereits 54.433 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
TOP! Unser Nr. 1 Neu! sevDataGrid 3.0 Mehrspaltige Listen, mit oder ohne DB-Anbindung. Autom. Sortierung, Editieren von Spalteninhalten oder das interaktive Hinzufügen von Datenzeilen sind ebenso möglich wie das Erstellen eines Web-Reports. Tipp des Monats Mai 2024 Hermann Röttger Wochentage eines Datumsbereichs ermitteln Wochentage eines Datumsbereichs ermitteln, optional mit Feiertagsberechnung Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |