Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Array of Weeks anhand Datum von - Datum bis (https://www.delphipraxis.net/211929-array-weeks-anhand-datum-von-datum-bis.html)

erich.wanker 23. Nov 2022 11:17

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

itblumi 23. Nov 2022 12:25

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.

dummzeuch 23. Nov 2022 12:39

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.

himitsu 23. Nov 2022 15:38

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....

Delphi-Referenz durchsuchenDayOfTheWeek
Delphi-Referenz durchsuchenStartOfTheWeek
Delphi-Referenz durchsuchenEndOfTheWeek
IncDay( , 7)
Delphi-Referenz durchsuchenIncWeek


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

dataspider 24. Nov 2022 10:58

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:
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
Abfrage:
SQL-Code:
select
  'Woche '||t.woche
, min(t.datum)
, max(t.datum)
  from sp_weeks(current_date, current_date + 50) t
  group by t.woche
Frank


Alle Zeitangaben in WEZ +1. Es ist jetzt 08:24 Uhr.

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