Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Tipps & Tricks ›

[gelöst] Datumsbereich ohne Wochenenden mit Computed Field

Eingetragen von Renardo (60)
am 04.01.2014 - 15:28 Uhr in
  • Tipps & Tricks
  • Drupal 7.x

Hallo,

ich errechne die Anzahl von Urlaubstagen mit Hilfe des Moduls Computed Field und folgendem Code. Das Problem dabei ist, dass hier auch die Wochenenden mitgerechnet werden:

     $start_value_url = $entity->field_erst_tag_url[LANGUAGE_NONE][0]['value'];
     $end_value_url = $entity->field_letzter_tag_url[LANGUAGE_NONE][0]['value2'];
     $timezone = $entity->field_erst_tag_url[LANGUAGE_NONE][0]['timezone'];
     $start_date = new DateObject($start_value_url, $timezone);
     $end_date = new DateObject($end_value_url, $timezone);
     $duration = $start_date->difference($end_date, 'days');
     $entity_field[0]['value'] = $duration+1;

Weiß jemand, wie ich das Ergebnis um die enthaltenen Wochenendtage kürzen kann?

Danke

Renardo

‹ Modul zum Sichern des files-Verzeichnisses via ftp [gelöst] Datumsbereich ohne Wochenenden mit Computed Field ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Keine Drupal Frage

Eingetragen von md (3717)
am 04.01.2014 - 18:16 Uhr

Das ist ja keine spezielle Drupal Frage.

Du brauchst einen Algorithmus der dieses Problem löst.
Und der Algorithmus muss mehr als Wochenenden berücksichtigen - z.B.

  • Wieviel Tage hat der Monat, in dem der Urlaub beginnt?
  • Wieviele Feiertage fallen in die Zeit des Urlaubs?
  • Liegt ein Feiertag an einem Wochenende?

Das sind wahrscheinlich nur einige Kriterien, die berücksichtigt werden müssten, um das Problem zu lösen.

Wenn man den Algorithmus hat, lässt sich das auch mit Drupal umsetzen.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Datumsbereich ohne Wochenenden mit Computed Field

Eingetragen von Renardo (60)
am 04.01.2014 - 18:52 Uhr

Warum soll das keine spezielle "Drupal-Frage" sein?

Ich realisiere mit Drupal 7 eine Urlaubsverwaltung und benutze hierfür u.a. das Modul Computed Field. Das funktioniert auch soweit ganz gut. Nur weiß ich nicht, wie ich den o.g. Code ändern muss, um die Wochenenden herauszurechnen.

Solche Fragen -auch zu dem erwähnten Modul- gab es hier schon öfters. Daher mein Anliegen bitte nicht einfach so abtun.

Danke

Renardo

  • Anmelden oder Registrieren um Kommentare zu schreiben

Ich habe die Frage nicht

Eingetragen von md (3717)
am 04.01.2014 - 19:23 Uhr

Ich habe die Frage nicht einfach so abgetan.

Ich habe darauf hingewiesen, dass es sich um ein komplexes Problem handelt, zu dessen Lösung ein Algorithmus benötigt wird.
Ein Algorithmus jedoch ist System- und Programmiersprachen unabhängig.

Einige Kriterien, die zu beachten sind, habe ich genannt. Die Lösung kann ich dir hier leider nicht liefern.
Vielleicht ein anderer Programmierer.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Ja vielleicht

Eingetragen von Renardo (60)
am 04.01.2014 - 19:43 Uhr

hilft mir ein anderer aus dem Forum hier oder hat zumindest eine konkrete Anfangsidee.

Renardo

  • Anmelden oder Registrieren um Kommentare zu schreiben

Hallovielleicht hift das

Eingetragen von oteno (775)
am 04.01.2014 - 20:38 Uhr

Hallo
vielleicht hilft das hier weiter:
http://stackoverflow.com/questions/336127/calculate-business-days
Gruß
Christian

  • Anmelden oder Registrieren um Kommentare zu schreiben

Datumsbereich ohne Wochenenden [gelöst]

Eingetragen von Renardo (60)
am 11.01.2014 - 18:14 Uhr

Ich habe die Lösung nun selbst hinbekommen. Die Anzahl von Urlaubstagen zwischen einem ersten und einem letzten Tag berechne ich so:

      $start_value_url = $entity->field_erster_tag_url[LANGUAGE_NONE][0]['value'];
      $end_value_url = $entity->field_letzter_tag_url[LANGUAGE_NONE][0]['value2'];

      $start = strtotime( $start_value_url);
      $end = strtotime($end_value_url);

      $count = 0;

      while(date('Y-m-d', $start) < date('Y-m-d', $end)){
      $count += date('N', $start) < 6 ? 1 : 0;
      $start = strtotime("+1 day", $start);
           }
      $entity_field[0]['value'] = $count+1;

Vielleicht hat ja jemand Lust, den Code für das "Computed Field" so zu erweitern, dass sich die deutschen Feiertage herausrechen lassen.

Renardo

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
  • Drupal 11 neu aufsetzen und Bereiche aus 10 importieren
  • Wie erlaubt man neuen Benutzern auf die Resetseite zugreifen zu dürfen.
  • [gelöst] Anzeigeformat Text mit Bild in einem Artikel, Drupal 11
  • Social Media Buttons um Insteragram erweitern
  • Nach Installation der neuesten D10-Version kein Zugriff auf Website
  • Composer nach Umzug
  • [gelöst] Taxonomie Begriffe zeigt nicht alle Nodes an
  • Drupal 11 + Experience Builder (Canvas) + Layout Builder
  • Welche KI verwendet ihr?
  • Update Manger läst sich nicht Installieren
Weiter

Neue Kommentare

  • melde mich mal wieder, da ich
    vor 1 Tag 7 Stunden
  • Hey danke
    vor 2 Tagen 2 Stunden
  • Update: jetzt gibt's ein
    vor 2 Tagen 20 Stunden
  • Hallo, im Prinzip habe ich
    vor 1 Woche 6 Stunden
  • Da scheint die Terminologie
    vor 1 Woche 9 Stunden
  • Kannst doch auch alles direkt
    vor 1 Woche 4 Tagen
  • In der entsprechenden View
    vor 1 Woche 4 Tagen
  • Dazu müsstest Du vermutlich
    vor 1 Woche 4 Tagen
  • gelöst
    vor 4 Wochen 1 Tag
  • Ja natürlich. Dass ist etwas,
    vor 4 Wochen 2 Tagen

Statistik

Beiträge im Forum: 250233
Registrierte User: 20449

Neue User:

  • Mroppoofpaync
  • 4aficiona2
  • AppBuilder

» Alle User anzeigen

User nach Punkten sortiert:
wla9461
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 17 Gäste online.

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association