![]() |
Array of Weeks anhand Datum von - Datum bis
Hallo,
Gegeben: Ich habe 2 Datumsfelder (von / bis) Ergebnis: ich bräuchte ein Array mit: Woche / datum_von / datum_bis Ergebnis sollte bei der Eingabe von 11.11.2022 bis 30.11.2022 sein "Woche 1" "2022-11-11" "2022-11-13" "Woche 2" "2022-11-14" "2022-11-20" "Woche 3" "2022-11-21" "2022-11-27" "Woche 4" "2022-11-28" "2022-11-30" Ich steh momentan komplett auf der Leitung - wie ich sowas lösen kann :-( Irgendwelche Vorschläge? Vielen Dank und schöne Grüße Erich |
AW: Array of Weeks anhand Datum von - Datum bis
Hallo Erich,
schau dir mal die Funktion WeekOf aus der Unit DateUtils an. Damit kannst du die start Woche ermitteln und sobald die Woche um 1 erhöht wird zum nächsten Array wechseln. |
AW: Array of Weeks anhand Datum von - Datum bis
Zuerst sicherstellen, dass das Anfangsdatum tatsächlich ein Montag ist. Wenn nicht evtl. korrigieren oder Fehler. Danach kann man das Anfangsdatum einfach immer um 7 erhöhen, das ist dann der nächste Montag (TDateTime speichert die Tage im ganzzahligen Anteil). Am Ende muss man auch noch entscheiden, ob man eine evtl. Teilwoche noch in der Liste haben will oder nicht.
|
AW: Array of Weeks anhand Datum von - Datum bis
Nja, die DateUtils bietet auch so Einiges, um nicht selber rechnen und mit unverständlichen Zahlen (7) umgehen zu müssen....
![]() ![]() ![]() IncDay( , 7) ![]() Das Erste ist datum_von bis EndOfTheWeek(datum_von) ... bzw. Min(EndOfTheWeek(datum_von), datum_bis). die nächsten sind dann "current" bis EndOfTheWeek(current) und dann ab dem ersten EndOfTheWeek mit IncWeek weiter, bis datum_bis |
AW: Array of Weeks anhand Datum von - Datum bis
Wenn es dein Projekt mit der Firebird Datenbank betrifft, dann würde ich das die Datenbank machen lassen:
Stored Proc:
SQL-Code:
Abfrage:
create or alter procedure sp_weeks (
von date, bis date) returns ( woche smallint, datum date) as begin woche = 1; while (:von <= :bis) do begin datum = :von; von = :von + 1; suspend; if (extract(weekday from :datum) = 0) then woche = :woche + 1; end end
SQL-Code:
Frank
select
'Woche '||t.woche , min(t.datum) , max(t.datum) from sp_weeks(current_date, current_date + 50) t group by t.woche |
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:08 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-2025 by Thomas Breitkreuz