Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. [gelöst] Letzter Tag eines beliebigen Monats ermitteln

    NEWS

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    [gelöst] Letzter Tag eines beliebigen Monats ermitteln

    This topic has been deleted. Only users with topic management privileges can see it.
    • M
      ManfredHi last edited by ManfredHi

      Hallo, ich bräuchte bitte wieder mal eure Hilfe.

      Ich habe ein Auswahlfeld für Monat und eines für Jahr. Wie kann ich in Blockly dann ermitteln, was der letzte Tag des ausgewählten Monats ist.?

      Homoran OliverIO 2 Replies Last reply Reply Quote 0
      • Homoran
        Homoran Global Moderator Administrators @ManfredHi last edited by

        @manfredhi sagte in Letzter Tag eines beliebigen Monats ermitteln:

        Wie kann ich in Blockly dann ermitteln, was der letzte Tag des ausgewählten Monats ist.?

        was willst du machen?
        den letzten Tag des Monats erkennen?
        oder
        die Anzahl Tage des aktuellen Monats berechnen?

        M 1 Reply Last reply Reply Quote 0
        • M
          ManfredHi @Homoran last edited by

          @homoran sagte in Letzter Tag eines beliebigen Monats ermitteln:

          letzten Tag des Mon

          Über ein zwei Listenfelder in der VIS wähle ich ein Monat und ein Jahr aus. Und es soll mir von diesem dann der letzte Tag im Monat ausgegeben werden. (28/29, 30 oder31).

          Homoran 1 Reply Last reply Reply Quote 0
          • Homoran
            Homoran Global Moderator Administrators @ManfredHi last edited by

            @manfredhi sagte in Letzter Tag eines beliebigen Monats ermitteln:

            @homoran sagte in Letzter Tag eines beliebigen Monats ermitteln:

            letzten Tag des Mon

            Über ein zwei Listenfelder in der VIS wähle ich ein Monat und ein Jahr aus. Und es soll mir von diesem dann der letzte Tag im Monat ausgegeben werden. (28/29, 30 oder31).

            also willst du

            @homoran sagte in Letzter Tag eines beliebigen Monats ermitteln:

            @manfredhi sagte in Letzter Tag eines beliebigen Monats ermitteln:

            Wie kann ich in Blockly dann ermitteln, was der letzte Tag des ausgewählten Monats ist.?

            was willst du machen?
            den letzten Tag des Monats erkennen?
            oder
            die Anzahl Tage des aktuellen Monats berechnen?

            1 Reply Last reply Reply Quote 0
            • M
              ManfredHi last edited by

              die Anzahl der Tage des gewählten Monats.
              Also wenn ich z.B. Bei Monat Februar und bei Jahr 2023 soll er dann 28 ausgeben.
              sorry wenn ich mich etwas unverständlich ausgedrückt hab.

              Homoran 1 Reply Last reply Reply Quote 0
              • Homoran
                Homoran Global Moderator Administrators @ManfredHi last edited by Homoran

                @manfredhi sagte in Letzter Tag eines beliebigen Monats ermitteln:

                die Anzahl der Tage des gewählten Monats.
                Also wenn ich z.B. Bei Monat Februar und bei Jahr 2023 soll er dann 28 ausgeben.
                sorry wenn ich mich etwas unverständlich ausgedrückt hab.

                wird wahrscheinlich auch irgendwie gehen, weiss aber nicht genau wie.

                Für die Erkennung des letzten Tages wird auf den aktuellen Timestamp 24h draufgerechnet und dann geprüft ob der Tag des nächsten Datums 1 ist.

                im Prinzip müsstest du in der Richtung ((28/29/30/31-aktueller Tag) + 24h) durchiterieren bis das Ergebnis 1 wird

                C 1 Reply Last reply Reply Quote 0
                • C
                  Chris87 @Homoran last edited by

                  @homoran
                  2efcbf25-90e0-46fa-82ad-de2aec714d86-image.png

                  So verwende ich das seit Jahren und funktioniert top.

                  /Chris

                  Homoran 1 Reply Last reply Reply Quote 0
                  • Homoran
                    Homoran Global Moderator Administrators @Chris87 last edited by

                    @chris87 sagte in Letzter Tag eines beliebigen Monats ermitteln:

                    So verwende ich das seit Jahren und funktioniert top.

                    ja!
                    das ist die Erkennung des Monatsletzen.

                    aber @ManfredHi will es auch am 3. / 7. oder 21. sehen wie viele Tage der aktuelle Monat hat.

                    ist etwas krumm rübergekommen

                    C 1 Reply Last reply Reply Quote 0
                    • C
                      Chris87 @Homoran last edited by

                      @homoran
                      Ah OK,
                      Da könnte man sowas doch nutzen und den aktuellen Tag abziehen:
                      7f7c44e6-f685-4fc5-8ba4-4cabdc24d4cd-image.png

                      Ja, ist nicht schön, aber einfach und funktionell.

                      /Chris

                      1 Reply Last reply Reply Quote 0
                      • M
                        ManfredHi last edited by

                        Ich hab mich vermutlich falsch ausgedrückt. Ich habe in meiner VIS folgende beiden Auswahlfelder:
                        ab11fc31-077b-45aa-8cdf-f510bfdc6031-image.png

                        Dazu habe ich zwei Datenpunkte:

                        61b1c4b5-c637-435d-843c-589e27938f0d-image.png

                        Der erste Tag im Monat ist einfach, weil ich dann nur "01" angeben muss. Allerdings brauch ich auch die zahl des letzten Tages des ausgewählten Monats und da komm ich nicht weiter.

                        Ich könnte es natürlich so lösen:

                        f6a43252-8ce1-4ea9-89bc-7823c39f9c2a-image.png

                        Aber da hab ich das Problem mit dem Februar, der ja ein Schaltjahr sein könnte und dann 29 Tage hat.

                        Dachte es gebe da eine "einfache" kürzere Lösung.

                        Homoran ofri2607 DJMarc75 3 Replies Last reply Reply Quote 0
                        • Homoran
                          Homoran Global Moderator Administrators @ManfredHi last edited by

                          @manfredhi sagte in Letzter Tag eines beliebigen Monats ermitteln:

                          Dachte es gebe da eine "einfache" kürzere Lösung.

                          ja!

                          @homoran sagte in Letzter Tag eines beliebigen Monats ermitteln:

                          im Prinzip müsstest du in der Richtung ((28/29/30/31-aktueller Tag) + 24h) durchiterieren bis das Ergebnis 1 wird

                          1 Reply Last reply Reply Quote 0
                          • ofri2607
                            ofri2607 @ManfredHi last edited by

                            @manfredhi
                            Ich kann dir leider bei Blockly nicht helfen da ich alles mit JS mache, nutze aber folgende Funktion in JS dafür, vielleicht hilft es dir ja trotzdem weiter:

                            //Letzter Tag des Monats
                                const isMonthLastDay = (y, m, d) => {
                                    let last = 31;
                                    if (m == 4 || m == 6 || m == 9 || m == 11) last -= 1;
                                    if (m == 2) {
                                        last -= 3;
                                        if ((y % 4 == 0 && y % 100 != 0) || (y % 400 == 0)) last += 1;
                                    };
                                    if (last == d) return true 
                                    else return false;
                                }
                            

                            Liefert true zurück wenn das übergebene Jahr (y), Monat (m) und Tag (d) - jeweils als Zahl - der Monatsletzte ist, sondern false.
                            Berücksichtigt auch das Schaltjahr im Februar.

                            Homoran paul53 2 Replies Last reply Reply Quote 0
                            • OliverIO
                              OliverIO @ManfredHi last edited by

                              @manfredhi

                              Ich kenne die Lösung zwar nicht für blockly, aber für javascript. Die Logik kann man aber sicherlich auch nachbilden
                              Zuerst ein datumsobjekt auf Basis des aktuellen Datums für den 1. Tag des folgemonats um 0 Uhr ermitteln. Dann eine Stunde abziehen (eigentlich egal) aber Ergebnis muss dann wieder im aktuellen Monat liegen. Dann den Tag des daraus ermittelten datumsobjekt wäre der letzte Tag des Monats

                              1 Reply Last reply Reply Quote 0
                              • Homoran
                                Homoran Global Moderator Administrators @ofri2607 last edited by

                                @ofri2607 sagte in Letzter Tag eines beliebigen Monats ermitteln:

                                Liefert true zurück wenn das übergebene Jahr (y), Monat (m) und Tag (d) - jeweils als Zahl - der Monatsletzte ist, sondern false.

                                ist aber auch nur die Erkennung des Monatsletzten.
                                Nicht die Berechnung der Anzahl Tage des aktuellen Monats

                                ofri2607 1 Reply Last reply Reply Quote 0
                                • DJMarc75
                                  DJMarc75 @ManfredHi last edited by

                                  @manfredhi

                                  Wenn es nur für den aktuellen Monat sein soll dann mach ich das so:

                                  Screenshot 2023-12-20 115624.png

                                  1 Reply Last reply Reply Quote 1
                                  • David G.
                                    David G. last edited by David G.

                                    Ich glaube ich würde wenn man in der Vis den den Oktober 23 auswählt im Blockly den 1.11.23 draus Machen und dann einen Tag abziehen.

                                    Dass der angezeigte DP im Oktober eine 10 ausgibt ist ja kein Problem, wird ja vermutlich auch so sein.

                                    1 Reply Last reply Reply Quote 1
                                    • paul53
                                      paul53 @ofri2607 last edited by

                                      @ofri2607 sagte: folgende Funktion in JS

                                      Blockly:

                                      Blockly_temp.JPG

                                      1 Reply Last reply Reply Quote 2
                                      • ofri2607
                                        ofri2607 @Homoran last edited by ofri2607

                                        @homoran sagte in Letzter Tag eines beliebigen Monats ermitteln:

                                        ist aber auch nur die Erkennung des Monatsletzten.
                                        Nicht die Berechnung der Anzahl Tage des aktuellen Monats

                                        Korrekt, ok hatte ich falsch verstanden.
                                        Leicht umgebaut liefert es auch die Anzahl der Tage:

                                        const monthDays = (y, m) => {
                                            let d = 31;
                                            if (m == 4 || m == 6 || m == 9 || m == 11) d -= 1;
                                            if (m == 2) {
                                                d -= 3;
                                                if ((y % 4 == 0 && y % 100 != 0) || (y % 400 == 0)) d += 1;
                                            };
                                            return d;
                                        };
                                        

                                        Edit: gerade gesehen, das @paul53 es schon als Blockly geliefert hat.

                                        1 Reply Last reply Reply Quote 0
                                        • M
                                          ManfredHi last edited by

                                          Danke für Eure Hilfe. Hab es im blockly wie @paul53 geschrieben hat umgesetzt !

                                          sten-tor 1 Reply Last reply Reply Quote 0
                                          • sten-tor
                                            sten-tor @ManfredHi last edited by

                                            @manfredhi Nur der Vollständigkeit halber noch ein anderer Ansatz: Man könnte auch vom ersten Tag des Folgemonats einen Tag abziehen und so auf den Monatsletzten schließen.

                                            bef88878-896c-4af1-ad80-9741e1887f8c-image.png

                                            Raidy007 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            767
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            12
                                            29
                                            1361
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo