Das deutsche QBasic- und FreeBASIC-Forum Foren-Übersicht Das deutsche QBasic- und FreeBASIC-Forum
Für euch erreichbar unter qb-forum.de, fb-forum.de und freebasic-forum.de!
 
FAQFAQ   SuchenSuchen   MitgliederlisteMitgliederliste   BenutzergruppenBenutzergruppen  RegistrierenRegistrieren
ProfilProfil   Einloggen, um private Nachrichten zu lesenEinloggen, um private Nachrichten zu lesen   LoginLogin
Zur Begleitseite des Forums / Chat / Impressum
Aktueller Forenpartner:

Bug in Day( date_serial )?

 
Neues Thema eröffnen   Neue Antwort erstellen    Das deutsche QBasic- und FreeBASIC-Forum Foren-Übersicht -> Allgemeine Fragen zu FreeBASIC.
Vorheriges Thema anzeigen :: Nächstes Thema anzeigen  
Autor Nachricht
hhm



Anmeldungsdatum: 28.04.2010
Beiträge: 8

BeitragVerfasst am: 06.05.2010, 17:36    Titel: Bug in Day( date_serial )? Antworten mit Zitat

Die Funktion Day(date_serial) gibt den Vortag an.

Rechnet man mit Day(date_serial +1) bekommt man meist ein richtiges Ergebnis, für den Monatsletzten jedoch stets 31. Auf den 27 Februar folgt also der 31. usw.

Weiß jemand mehr darüber?
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden
MOD
Fleißiger Referenzredakteur


Anmeldungsdatum: 10.09.2007
Beiträge: 1003

BeitragVerfasst am: 06.05.2010, 17:47    Titel: Antworten mit Zitat

Code:
#Include "vbcompat.bi"
Print Day(Now)
Sleep


Das gibt mir (heute) 6 aus, also richtig.
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden
volta



Anmeldungsdatum: 04.05.2005
Beiträge: 1876
Wohnort: D59192

BeitragVerfasst am: 06.05.2010, 22:46    Titel: Antworten mit Zitat

Hi,
Die Funktion Day(DateSerial(Jahr,Monat,Tag)) gibt den aktuellen Tag an.
Nicht den Vortag!
Z.B.
Code:
#INCLUDE "vbcompat.bi"
PRINT DAY(DateSerial(2010, 2, 28) + 1)
SLEEP
gibt als Folgetag des 28.02.2010 den 1. an. Also OK.

http://www.freebasic-portal.de/befehlsreferenz/serial-numbers-461.html hat Folgendes geschrieben:
Der erste Teil ist der ganzzahlige Teil, der die Anzahl der Tage, die seit dem 30.12.1899 um 00:00 vergangen sind, angibt.

_________________
Warnung an Choleriker:
Dieser Beitrag kann Spuren von Ironie & Sarkasmus enthalten.
Zu Risiken & Nebenwirkungen fragen Sie Ihren Therapeuten oder Psychiater.
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden Website dieses Benutzers besuchen
hhm



Anmeldungsdatum: 28.04.2010
Beiträge: 8

BeitragVerfasst am: 07.05.2010, 10:57    Titel: Antworten mit Zitat

Alles klar!

Das Problem liegt in der Format-Funktion:

Code:

Format(Day(serial_date), "dd")


liefert ein falsches Ergebnis.

Es muß heißen:

Code:
Format(serial_date, "dd")
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden
Sebastian
Administrator


Anmeldungsdatum: 10.09.2004
Beiträge: 5969
Wohnort: Deutschland

BeitragVerfasst am: 07.05.2010, 12:53    Titel: Antworten mit Zitat

hhm hat Folgendes geschrieben:
Alles klar!

Das Problem liegt in der Format-Funktion:

Code:

Format(Day(serial_date), "dd")


liefert ein falsches Ergebnis.

Es muß heißen:

Code:
Format(serial_date, "dd")

Die Problemlösung ist zwar richtig, aber das ist kein Fehler der Format-Funktion! Wenn du von FORMAT ein Datum formatieren lässt (Formatierungsplatzhalter "dd"), musst du auch ein Datum als zu formatierenden Wert übergeben und nicht nur eine Zahl von 1 bis 31, was aber von DAY als Rückgabe erzeugt wird.

Das folgende Beispiel zeigt, welches Datum sich z. B. hinter dem FB-Zeitstempel 7 verbirgt und wie das heutige Datum als Zeitstempel aussieht:
Code:
#include "vbcompat.bi"

Dim As Double ZeitpunktA = 40305.53113425926, _
              ZeitpunktB = 7

Print "Formatieren von ZeitpunktA (= ca. " & INT(ZeitpunktA) & "):"
Print
Print "Tag des Monats: " & Format(ZeitpunktA,"dd")
Print Format(ZeitpunktA,"dd.mm.yyyy")
Print Format(ZeitpunktA,"ddddd")
Print Format(ZeitpunktA,"dd.mm.yy hh:mm:ss")
Print "Wochentag: " & Weekday(ZeitpunktA) & " (" & WeekdayName(Weekday(ZeitpunktA)) & ")"

Print
Print
Print "Jetzt ZeitpunktB (= " & ZeitpunktB & ") formatieren:"
Print
Print "Tag des Monats: " & Format(ZeitpunktB,"dd")
Print Format(ZeitpunktB,"dd.mm.yyyy")
Print Format(ZeitpunktB,"ddddd")
Print Format(ZeitpunktB,"dd.mm.yy hh:mm:ss")
Print "Wochentag: " & Weekday(ZeitpunktB) & " (" & WeekdayName(Weekday(ZeitpunktB)) & ")"

Sleep

_________________

Die gefährlichsten Familienclans | Opas Leistung muss sich wieder lohnen - für 6 bis 10 Generationen!
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden E-Mail senden Website dieses Benutzers besuchen
Beiträge der letzten Zeit anzeigen:   
Neues Thema eröffnen   Neue Antwort erstellen    Das deutsche QBasic- und FreeBASIC-Forum Foren-Übersicht -> Allgemeine Fragen zu FreeBASIC. Alle Zeiten sind GMT + 1 Stunde
Seite 1 von 1

 
Gehe zu:  
Du kannst keine Beiträge in dieses Forum schreiben.
Du kannst auf Beiträge in diesem Forum nicht antworten.
Du kannst deine Beiträge in diesem Forum nicht bearbeiten.
Du kannst deine Beiträge in diesem Forum nicht löschen.
Du kannst an Umfragen in diesem Forum nicht mitmachen.

 Impressum :: Datenschutz