ABOUT Visual Basic Programmieren Programmierung Download Downloads Tips & Tricks Tipps & Tricks Know-How Praxis VB VBA Visual Basic for Applications VBS VBScript Scripting Windows ActiveX COM OLE API ComputerPC Microsoft Office Microsoft Office 97 Office 2000 Access Word Winword Excel Outlook Addins ASP Active Server Pages COMAddIns ActiveX-Controls OCX UserControl UserDocument Komponenten DLL EXE
Diese Seite wurde zuletzt aktualisiert am 16.01.2002

Diese Seite wurde zuletzt aktualisiert am 16.01.2002
Aktuell im ABOUT Visual Basic-MagazinGrundlagenwissen und TechnologienKnow How, Tipps und Tricks rund um Visual BasicActiveX-Komponenten, Controls, Klassen und mehr...AddIns für die Visual Basic-IDE und die VBA-IDEVBA-Programmierung in MS-Office und anderen AnwendungenScripting-Praxis für den Windows Scripting Host und das Scripting-ControlTools, Komponenten und Dienstleistungen des MarktesRessourcen für Programmierer (Bücher, Job-Börse)Dies&Das...

Themen und Stichwörter im ABOUT Visual Basic-Magazin
Code, Beispiele, Komponenten, Tools im Überblick, Shareware, Freeware
Ihre Service-Seite, Termine, Job-Börse
Melden Sie sich an, um in den vollen Genuss des ABOUT Visual Basic-Magazins zu kommen!
Informationen zum ABOUT Visual Basic-Magazin, Kontakt und Impressum

Zurück...

Kalenderwochenjahr

Zurück...


Anzeige

(-hg) mailto:hg_weekyear@aboutvb.de

Es gibt Jahre, in denen die letzten Tage des Dezembers bereits zur ersten Kalenderwoche des darauffolgenden Jahres zählen (etwa in 2001, 2002 und 2003). Leider gibt es keine VB(A)-Funktion, die Ihnen zu einem Datum wie "31.12.2001" die korrekte Angabe der Jahres-Kalenderwoche etwa in der Form "1/2002" liefern könnte. Immerhin liefert die DatePart-Funktion zum Intervall "w" die richtige Kalenderwoche 1. Jedoch liefert sie zum Intervall "yyyy" das für das Datum selbst zwar korrekte Jahr 2001, was allerdings eben nicht das Jahr der Kalenderwoche ist.

Hier hilft nur eine ausdrückliche Interpretation von Kalenderwoche und Jahr zu einem Datum, um das korrekte Kalenderwochenjahr zu ermitteln: Wenn zu einem Datum im Monat 12 die Kalenderwoche 1 lautet, kann es sich nur um das Folgejahr handeln.

Die Funktion YearOfWeek liefert entsprechend dieser Regel das Kalenderwochenjahr zu einem gegebenen Datum:

Public Function YearOfWeek(ByVal TestDate As Date, _
 Optional ByVal FirstDayOfWeek As VbDayOfWeek _
  = vbUseSystemDayOfWeek, _
 Optional ByVal FirstWeekOfYear As VbFirstWeekOfYear _
  = vbUseSystem) As Integer

  If Month(TestDate) = 12 Then
    If DatePart("ww", TestDate, _
     FirstDayOfWeek, FirstWeekOfYear) = 1 Then
      YearOfWeek = Year(TestDate) + 1
      Exit Function
    End If
  End If
  YearOfWeek = Year(TestDate)
End Function

Sowohl die Kalenderwoche als auch das Kalenderwochenjahr in einem Aufwasch ermittelt die Funktion WeekYear. Sie liefert die Kalenderwoche direkt als Rückgabewert der Funktion. Für das Kalenderwochenjahr können Sie eine separate Variable deklarieren, die Sie optional als zweiten Parameter übergeben können.

Public Function WeekYear(ByVal TestDate As Date, _
 Optional YearOfWeek As Variant, _
 Optional ByVal FirstDayOfWeek As VbDayOfWeek _
  = vbUseSystemDayOfWeek, _
 Optional ByVal FirstWeekOfYear As VbFirstWeekOfYear _
  = vbUseSystem)

  WeekYear = _
   DatePart("ww", TestDate, FirstDayOfWeek, FirstWeekOfYear)
  If Not IsMissing(YearOfWeek) Then
    If Month(TestDate) = 12 Then
      If WeekYear = 1 Then
        YearOfWeek = Year(TestDate) + 1
        Exit Function
      End If
    End If
    YearOfWeek = Year(TestDate)
  End If
End Function

Beide Funktionen verwenden voreingestellt die Systemeinstellungen für die Definitionen von erstem Wochentag und erster Kalenderwoche. In den optionalen Parametern FirstDayOfWeek und FirstWeekOfYear können Sie abweichende Definitionen festlegen.


Modul modWeekYear (modWeekYear.bas - ca. 1,2 KB)


Artikel
Zum Download-Bereich dieses Artikel
Mail an den Autor dieses Artikels

KnowHow
Zur KnowHow-Übersicht

KnowHow-Themen
Themen - Allgemeines
Themen - Entwicklungsumgebung (VB-IDE)
Themen - Forms
Themen - Steuerelemente (Controls)
Themen - Grafik
Themen - Dateien
Themen - UserControls
Themen - Einsteiger-Tipps
Themen - Wussten Sie...?

Übersicht nach Titeln in alphabetischer Reihenfolge
Übersicht nach Erscheinungsdatum

Schnellsuche




Zum Seitenanfang

Copyright © 1999 - 2017 Harald M. Genauck, ip-pro gmbh  /  Impressum

Zum Seitenanfang

Zurück...

Zurück...

Download Internet Explorer