Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   Delphi Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln (https://www.delphipraxis.net/202943-anzahl-monate-und-anzahl-wochen-seit-dem-01-01-0001-ermitteln.html)

juergen 27. Dez 2019 17:41

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:
    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;
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:

Hat jemand einen Vorschlag wie man das lösen kann, bzw. wo mein Denkfehler liegt?


Vielen Dank schon mal vorab!

hoika 27. Dez 2019 17:50

AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
 
Hallo,
einen C-Pseudo-Code habe ich hier gefunden:
https://www.academia.edu/1091577/Wha...was_01-01-0001

Die Frage ist u.a., ab wann gibt es Schaltjahre.

Der schöne Günther 27. Dez 2019 18:02

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.

hoika 27. Dez 2019 18:15

AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
 
Hallo,
und angeblich gab es ja 300 Jahre vor 1000 gar nicht ...

Redeemer 27. Dez 2019 18:37

AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
 
Zitat:

Zitat von juergen (Beitrag 1453988)
Hallo zusammen,

ich muss die Anzahl der Monate und Wochen seit dem 01.01.0001 bis zu einem frei auswählbaren Datum ermitteln.

Warum "muss"?

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.

p80286 27. Dez 2019 18:40

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

juergen 27. Dez 2019 19:02

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.

Redeemer 27. Dez 2019 19:20

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?

p80286 27. Dez 2019 21:06

AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
 
Zitat:

Zitat von juergen (Beitrag 1453996)
Die Anzahl von Wochen und Monaten stehen in einigen Tabellen einer Datenbank.

Bitte etwas detailierter. Ich wette daß da niemand vom 01.01.01 an gezählt hat. Wahrscheinlich gibt es einen Startwert auf dem die Zählungen basieren.

(Wie rechnet man eigentlich den franz. Revolutionskalender um?)

Gruß
K-H

stpolster 27. Dez 2019 22:21

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 14:05 Uhr.
Seite 1 von 3  1 23      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz