VB.Net – Datum

Des öfteren habe ich das Problem das ich eine Datei mit einen Datum versehen möchte. Zum Beispiel soll ein Logfile erstellt werden in welchen das Datum im Dateinamen enthalten ist. Man könnte nun ganz einfach das heutige Datum nehmen und daraus den Dateinamen bilden. Dies würde dann so aussehen:

24.09.2009_log.txt oder 24. September 2009_log.txt
Diese Sonderzeichen (“.”) sind unter Windows durchaus zulässig und Windows kann mit solchen Sonderzeichen umgehen. Wie hier nach zu lesen ist, dürfen nur diese Sonderzeichen “< > ? ” : | \ / *” nicht in Dateinamen verwendet werden. Doch trennt der Punkt eigentlich die Dateierweiterung vom Dateinamen. Etwas eleganter könnte es so aussehen:
2009_09_24_log.txt oder 24_september_2009.txt
Wobei die Angabe Jahr, Monat, Tag sich perfekt für die Sortierung an Hand des Dateinamen eignet.
Nun zum praktischen.

Public date_complete(5) as String

In diesen Beispiel lege ich eine globale Variable(Array) an, um später komfortabel überall darauf zu zugreifen.

Public Sub func_full_date

Ein Funktion ist nicht notwendig, da ich die globale Variablen innerhalb der Sub bestücke. Also kein Return.

Dim datum As Date

Datums Variable definieren.

date_complete(0) = datum.today.Year

Das Jahr in das erste Arrayfeld.

If datum.today.Month < = 9 Then
    date_complete(1) = "0" & datum.today.Month
Else
    date_complete(1) = datum.today.Month
End If

Prüfen ob der Monat unter 10 liegt um nicht z.B. 9 sondern 09 zu erhalten, deswegen auch das Array als String.

If datum.today.day < = 9 Then
    date_complete(2) = "0" & datum.today.day
Else
    date_complete(2) = datum.today.day
End If

Tage

If datum.today.hour < = 9 Then
    date_complete(3) = "0" & datum.today.Hour
Else
    date_complete(3) = datum.today.Hour
End If

Stunden

If datum.today.Minute < = 9 Then
    date_complete(4) = "0" & datum.today.minute
Else
    date_complete(4) = datum.today.minute
End If

Minuten

If datum.today.Second < = 9 Then
    date_complete(5) = "0" & datum.today.Second
Else
    date_complete(5) = datum.today.Second
End If

Sekunden

End Sub

Wie man sehen kann fange ich die Zahlen kleiner 10 ab und setze ein Null davor. Somit erhält man das Datum 2009_09_24 anstatt 2009_9_24.
Die Sub nutzt man wie folgt:

call func_full_date

Sub aufrufen > date_complete wird mit dem aktuellen Datum und der aktuellen Uhrzeit bestückt.
Das Array ist nach dem ausführen der Sub mit folgenden Werten gefüllt.

date_complete(0) = 2009 'Jahr
date_complete(1) = 09 'Monat
date_complete(2) = 24 'Tag
date_complete(3) = 20 'Stunde
date_complete(4) = 50 'Minuten
date_complete(5) = 20 'Sekunden

Hier noch die komplette Funktion.

Public Sub func_full_date
Dim datum As Date
date_complete(0) = datum.today.Year
If datum.today.Month < = 9 Then
    date_complete(1) = "0" & datum.today.Month
Else
    date_complete(1) = datum.today.Month
End If
If datum.today.day < = 9 Then
    date_complete(2) = "0" & datum.today.day
Else
    date_complete(2) = datum.today.day
End If
If datum.today.hour < = 9 Then
    date_complete(3) = "0" & datum.today.Hour
Else
    date_complete(3) = datum.today.Hour
End If
If datum.today.Minute < = 9 Then
    date_complete(4) = "0" & datum.today.minute
Else
    date_complete(4) = datum.today.minute
End If
If datum.today.Second < = 9 Then
    date_complete(5) = "0" & datum.today.Second
Else
    date_complete(5) = datum.today.Second
End If
End Sub