Deutsch
Quelltexte/ Codesnippets

Datum Einige Routinen Zeit - 2

 

KompilierenMarkierenSeparieren
Source wurde am 15.07.2007 aus der MMJ-Quellcodesammlung (Dietmar Horn) in die Babyklappe auf XProfan.Com abgelegt:
Datum und Zeit: Einige Zeit- und Datum-Routinen
PRFellow-Vorlage
Autor: Thomas Hölzer
Einige kleine Zeit-/Datumroutinen
(siehe auch Vorlagen ostern.prv, feiertag.prv,wochtag.prv)
Schaltjahr?
Rückgabe: 0 = Nein, 1 = Ja
Def IsLeapYear(1) If(Or(And(Equ(Mod(%(1),4),0),Neq(Mod(%(1),100),0)),
Equ(Mod(%(1),400),0)),1,0)
Werte, mit denen man rechnen kann
Def Hour(0) Val(SubStr$(Time$(0),1,:))
Def Min(0) Val(SubStr$(Time$(0),2,:))
Def Sec(0) Val(SubStr$(Time$(1),1,.))
Def Day(0) Val(SubStr$(Date$(0),1,.))
Def Month(0) Val(SubStr$(Date$(0),2,.))
Def Year(0) Val(SubStr$(Date$(0),3,.))
Der wievielte Tag im Jahr ist der tt,mm,jjjj?
Die Prozedur NrOfDay verwendet einen Hilfsstring anstelle eines Arrays oder einer
List%-Liste, um auf globale Variablen verzichten zu können.
Das ganze sieht komplizierter aus als es ist:
Um sich reinzudenken, beachte man bitte, daß jeder Monat zunächst
mit 28 Tagen angenommen wird und der jeweilige Mehrwert im String
an eindeutiger Stelle steht(Monat * 2) (Multiplikator 2 wg. zweistelliger Zahlen)
Also: Die Mehrwert-Tage für Januar stehen an Stringposition 2, für Februar an 4,
für März an 6,usw., für Dezember an 24.
Beispiel für den 31.12.1998:
Man berechnet zunächst die Tage bis Ende des Vormonats: 11 * 28
Dann schaut man im String an Position 24 für Dezember nach, wieviele Tage
Mehrwert zuzuschlagen sind und findet 26
Dann addiert man die Tageszahl des gewünschten Monats dazu.
Falls das gewünschte Jahr ein Schaltjahr ist und der gewünschte Monat auf den Februar folgt,
muß das Ergebnis noch einmal um 1 erhöht werden (der 29. Februar).
Dafür ist die Zusatzfunktion IsLeapYear erforderlich, die für 1999 0 zurückgibt
Ergebnis
(11 Monate * 28 Tage) + 26 Mehrtage + Tageszahl 31 + Schaltjahrwert 0 = 365
In fertigen Programmen sollte noch sichergestellt werden, daß nur
gültige Daten übergeben werden können!

Proc NrOfDay

    Parameters t%,m%,j%
    Declare result%,mehrtage%
    Let mehrtage%=Val(Mid$(0000303060811131619212426,Mul(m%,2),2))
    Let result%=Add(Add(Mul(Sub(m%,1),28),t%),mehrtage%)
    Case Gt(m%,2): Add result%,IsLeapYear(j%)
    Return result%

EndProc

Beispiel
NrOfDay 31,12,2000
Print Silvester ist der,%(0);. Tag im Jahr 2000
WaitInput
 
15.07.2007  
 



Zum Quelltext


Thementitel, max. 100 Zeichen.
 

Systemprofile:

Kein Systemprofil angelegt. [anlegen]

XProfan:

 Beitrag  Schrift  Smilies  ▼ 

Bitte anmelden um einen Beitrag zu verfassen.
 

Themenoptionen

1.990 Betrachtungen

Unbenanntvor 0 min.
H.Brill09.10.2021
Torben Nissen01.07.2021
Langer03.04.2017
ByteAttack11.08.2014
Mehr...

Themeninformationen

Dieses Thema hat 1 Teilnehmer:

unbekannt (1x)


Admins  |  AGB  |  Anwendungen  |  Autoren  |  Chat  |  Datenschutz  |  Download  |  Eingangshalle  |  Hilfe  |  Händlerportal  |  Impressum  |  Mart  |  Schnittstellen  |  SDK  |  Services  |  Spiele  |  Suche  |  Support

Ein Projekt aller XProfaner, die es gibt!


Mein XProfan
Private Nachrichten
Eigenes Ablageforum
Themen-Merkliste
Eigene Beiträge
Eigene Themen
Zwischenablage
Abmelden
 Deutsch English Français Español Italia
Übersetzungen

Datenschutz


Wir verwenden Cookies nur als Session-Cookies wegen der technischen Notwendigkeit und bei uns gibt es keine Cookies von Drittanbietern.

Wenn du hier auf unsere Webseite klickst oder navigierst, stimmst du unserer Erfassung von Informationen in unseren Cookies auf XProfan.Net zu.

Weitere Informationen zu unseren Cookies und dazu, wie du die Kontrolle darüber behältst, findest du in unserer nachfolgenden Datenschutzerklärung.


einverstandenDatenschutzerklärung
Ich möchte keinen Cookie