![]() |
Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Hallo zusammen,
ich muss die Anzahl der Monate und Wochen seit dem 01.01.0001 bis zu einem frei auswählbaren Datum ermitteln. Das Problem: Alle Funktionen die ich kenne nutzen Date(time) welche wohl nur einen Gültigkeitsbereich bis 30.12.1899 haben. Jetzt habe ich schon etwas getrickst mit abs(ISO8601ToDate(…)), aber irgendwas funktioniert da noch nicht 100%ig. Hier einer meiner Versuche:
Delphi-Quellcode:
Ganz grob stimmt die Anzahl der Monate und Wochen, aber eben nicht 100%ig. Z.B. erhöht sich die Anzahl der Monate erst ab dem 03.04.2019 anstelle ab dem 01.04.2019. Wenn ich als Datum den 01.05.2019 auswähle, erhöht sich dann aber die Anzahl der Monate korrekt.:gruebel:
li_Anzahl_Tage_vom_01_01_0001_bis_gewaehltesDatum := Trunc(abs(ISO8601ToDate('0001-01-01'))) + Trunc(cxDateEdt_Ende_Datum.Date);
FOR I := 1 TO li_Anzahl_Tage_vom_01_01_0001_bis_gewaehltesDatum DO BEGIN DecodeDateMonthWeek(i, lw_Jahr, lw_Monat, lw_Woche, lw_Tag); DecodeDateMonthWeek(i - 1, lw_Jahr_vorheriger_DS, lw_Monat_vorheriger_DS, lw_Woche_vorheriger_DS, lw_Tag_vorheriger_DS); IF lw_Monat <> lw_Monat_vorheriger_DS THEN BEGIN Inc(li_Zaehler_Monat); END; IF lw_Woche <> lw_Woche_vorheriger_DS THEN BEGIN Inc(li_Zaehler_Woche); END; END; Hat jemand einen Vorschlag wie man das lösen kann, bzw. wo mein Denkfehler liegt? Vielen Dank schon mal vorab! |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Hallo,
einen C-Pseudo-Code habe ich hier gefunden: ![]() Die Frage ist u.a., ab wann gibt es Schaltjahre. |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Vor 1582 gab es noch keinen gregorianischen Kalender, und auf dem basiert ISO8601.
Davor waren (nach dem julianischen Kalender) noch nichtmal die Jahre so lang wie heute. |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Hallo,
und angeblich gab es ja 300 Jahre vor 1000 gar nicht ... |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Zitat:
Die Aufgabe ist einfach dumm gestellt und ohne Angabe eine genauen Standortes unmöglich zu lösen, da (wenn wir mal julianische und gregorianische Kalender annehmen, und den neujulianischen rauslassen) abhängig vom Standort unterschiedliche und unterschiedlich viele Tage (mindestens 10) nicht definiert sind. Angenommen, du befändest dich im HRR, dann könntest du den 5.–14. Oktober 1682 einfach nicht berechnen, weil es diese Tage im HRR niemals gab. In Schweden vom 30. Februar 1712 zu sprechen, ist hingegen völlig in Ordnung. |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
klingt nach Pseudogenauigkeit..
oder die Aufgabe hat jemand gestellt der nicht wußte wovon er spricht Gruß K-H |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Hallo,
ja, meine Angaben sind wohl unvollständig. Die Anzahl von Wochen und Monaten stehen in einigen Tabellen einer Datenbank. ich muss damit "irgendwie" zurecht kommen. Datumswerte gibt es nicht. Ich muss z.B. alle Datensätze auslesen, die vom April 2019 sind. Das entspricht der Anzahl von Monaten => 24220. Ich gehe davon aus, dass als Grundlage für die Berechnungen rückwirkend bis zum 01.01.0001 der heute gültige Kalender/ -regeln gelten. Vermutlich muss ich das rein mathematisch lösen. |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Ja gut, das geht ja einfach mit DIV und MOD. Dankbarerweise sind in der Geschichte keine ganzen Monate ausgefallen.
Aber soll das jetzt mit den Wochen sein? |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Zitat:
(Wie rechnet man eigentlich den franz. Revolutionskalender um?) Gruß K-H |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Für solche Berechnungen kennt die Astronomie das Julianische Datum; hat nichts mit dem Julianischen Kalender zu tun.
Die Tage werden fortlaufend ab dem 1.1.4713 v.Z. 12 Uhr durchnummeriert. Algorithmus: Gegeben ist ein beliebiges (gültiges) Datum (tag.monat.jahr) sowohl im Gregorianischen als auch Julianischen Kalender. Dann gibt folgender Algorithmus das Julianische Datum JD. K = 10000· jahr + 100·monat + tag B = -63,5 Y = jahr + 4712 M = monat + 1 Wenn monat <= 2 dann Y = Y-1 und M = M +12 Wenn K >= 15821015 dann A = INT[(Y+88)/100] und B = B +38 - A + INT[A/4] JD = INT[365,25·Y] + INT[30,6001·M] + tag +B INT[ ] ist dabei der ganzzahlige Anteil des Ergebnisses Die Differenz zweier Julianischer Daten ist dann die Anzahl der Tage zwischen den Daten. LG Steffen |
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:14 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz