vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#

https://www.vbarchiv.net
Rubrik: Datum/Zeit und Timer · Datums- und Zeit-Funktionen   |   VB-Versionen: VB2005 - VB201508.07.16
Kalenderwoche korrekt ermitteln II

Leider funktioniert die DatePart-Funktion in Bezug auf das Ermitteln der Kalenderwoche nicht korrekt. Dieser Tipp schafft Abhilfe.

Autor:   Helmut KranerBewertung:  Views:  6.309 
ohne HomepageSystem:  Win7, Win8, Win10, Win11 Beispielprojekt auf CD 

Die korrekte Kalenderwoche (auch am Jahresende) hab ich folgendermassen gelöst:

Ich addiere einfach 7 Tage zum Datum dazu und prüfe, ob Woche 2 rauskommt. Wenn ja, ist logischerweise die richtige Kalenderwoche die 1 (und nicht die KW 53, wie z. B. am 31.12.2007). Ansonsten ermittle ich nochmals mit dem übergebenen Datum die Kalenderwoche.

''' <summary>
''' Kalenderwoche korrekt ermitteln
''' </summary>
''' <param name="Datum">Datum, für das die Kalenderwoche ermittelt werden soll</param>
''' <returns>Kalenderwoche</returns>
Public Function Kalenderwoche(ByVal Datum As Date) As Integer
  Dim CUI As New System.Globalization.CultureInfo( _
    System.Globalization.CultureInfo.CurrentCulture.Name)
 
  If CUI.Calendar.GetWeekOfYear(Datum.AddDays(7), _
    CUI.DateTimeFormat.CalendarWeekRule, CUI.DateTimeFormat.FirstDayOfWeek) = 2 Then
 
    Return 1
  Else
    Return CUI.Calendar.GetWeekOfYear(Datum, _
      CUI.DateTimeFormat.CalendarWeekRule, CUI.DateTimeFormat.FirstDayOfWeek)
  End If
End Function



Anzeige

Kauftipp Unser Dauerbrenner!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.
 
 
Copyright ©2000-2024 vb@rchiv Dieter OtterAlle Rechte vorbehalten.


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.