Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Zeitdifferenz berechnen

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    Zeitdifferenz berechnen

    This topic has been deleted. Only users with topic management privileges can see it.
    • ?
      A Former User @paul53 last edited by

      @paul53 Ah ich hab es. Und wie bringe ich dann die Variable auf den DP? Weil ich ja aktuell nur auf die Variable schreiben kann. Oder nehme ich da ein anderes Element dann für?

      paul53 1 Reply Last reply Reply Quote 0
      • paul53
        paul53 @Guest last edited by

        @Alina sagte:

        wie bringe ich dann die Variable auf den DP?

        Blockly_temp.JPG

        ? 1 Reply Last reply Reply Quote 0
        • ?
          A Former User @paul53 last edited by

          @paul53

          Stimmt, sorry für die letzte doofe Frage. Viele Vielen Dank 💃

          1 Reply Last reply Reply Quote 0
          • ?
            A Former User @paul53 last edited by

            @paul53 Und das Ergebnis sind dann Sekunden, richtig?

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

              @Alina diff_in_ms

              ? 1 Reply Last reply Reply Quote 0
              • ?
                A Former User @Homoran last edited by

                @Homoran Simmt. Steht da. Danke ✌ )

                M 1 Reply Last reply Reply Quote 0
                • M
                  Matthias I @Guest last edited by

                  Hallo,

                  ich möchte gerne meinen Rasenmähroboter "smart" machen um folgendes Problem zu lösen:
                  Der Robotor fährt derzeit nach eingestelltem Zeitplan, jedoch nicht, wenn es regnet oder die Terrassentür geöffnet ist (damit er dem Hund nicht über die Pfote fährt). Hierdurch wird die wöchentliche Mähzeit jedoch zum Teil so stark reduziert, dass der Rasen unzureichend gemäht wird. Das verlängern der Zeitintervalle führt umgekehrt dazu, dass bei anhaltend regenfreiem Wetter und geschlossener Terrassentüre der Rassenrobbi so lange fährt, dass an den Rändern, wo er sich dreht kein Gras mehr wechst.

                  Ich weiß aus Erfahrung jedoch wie lange der Robbi wöchentlich in etwa mähen muss, damit das Gras "im Zaum gehalten wird" und keine kahlen Stellen entstehen.

                  Mein Plan ist deshalb den Zeitplan des Mähroboters zu erweitern, ihn aber nur dann mähen zu lassen, wenn die wöchentliche max. Mähzeit nicht überschritten ist und ihn bei unterschreiten einer minimalen Mähzeit am Wochenende auch außerhalb des Zeitplans mähen zulassen, um "Mähzeit nachzuholen".

                  Also möchte ich mir gerne vom ioBroker berechnen lassen, wie lange mein Rasenmähroboter gemäht hat.
                  Dazu soll wenn der Datenpunkt Zustand auf "mähen" springt, die Startzeit erfasst werden und wenn sich der Zustand ändert soll die Endzeit erfasst werden.
                  Aus Endzeit - Startzeit soll dann die Mähdauer in der Form SS:MM:ss berechnet werden.
                  Das habe ich folgendermaßen umgesetzt:

                  Bild_2021-03-04_170945.png

                  Bei der Berechnung der Mähzeit stimmt aber leider der ausgegebene Wert nicht! Dieser ist immer um genau 1 Std. zu hoch!
                  Könnt ihr mir sagen, was ich falsch mache?
                  Kann es damit zusammen hängen, dass Systemzeit und Zeitstempel (WARUM AUCH IMMER) 1 Stunde auseinander liegen?

                  paul53 1 Reply Last reply Reply Quote 0
                  • paul53
                    paul53 last edited by paul53

                    @matthias-i sagte: Mähdauer in der Form SS:MM:ss berechnet werden.

                    Die Formatierung berücksichtigt die Zeitzone, die man kompensieren muss.

                    Es genügt ein Trigger beim Ausschalten (ist kleiner als letztes).

                    Bild_2021-03-04_173245.png

                    M 1 Reply Last reply Reply Quote 0
                    • M
                      Matthias I @paul53 last edited by

                      @paul53 Vielen Dank, das habe ich hinbekommen 🙂

                      Die Fahrdauer wird jetzt richtig berechnet, jetzt müsste ich nur noch wissen, wie man Zeiten addieren kann.
                      D.h. wie kann ich zwei Datenpunkte (Zeichenkette in der Form SS:MM:ss) miteinander addieren?

                      Noch eleganter wäre es natürlich eine Liste "TagMähzeiten" anzulegen, die um Mitternacht geleert wird und in der die einzelnen Mähzeiten eingetragen und zum Schluss addiert werden. Ist so etwas auch umsetzbar? (Mit Listen habe ich noch nicht gearbeitet.)

                      paul53 1 Reply Last reply Reply Quote 0
                      • paul53
                        paul53 @Matthias I last edited by

                        @matthias-i sagte: jetzt müsste ich nur noch wissen, wie man Zeiten addieren kann.

                        "erhöhe einschaltdauer" kumuliert bereits. Man müsste also den Wert einmal pro Woche auf 0 zurück setzen.

                        M 2 Replies Last reply Reply Quote 0
                        • M
                          Matthias I @paul53 last edited by

                          @paul53 ich habe das auf folgendem Wege gelöst:
                          Bild_2021-03-04_185032.png
                          Im nächsten Schritt müsste jetzt "LaufzeitAktuell" nach jedem Mähen zu "LaufzeitTag" addiert werden.

                          1 Reply Last reply Reply Quote 0
                          • M
                            Matthias I @paul53 last edited by

                            @paul53 ich habe es wie folgt hinbekommen:
                            Datum/Zeit nach String konvertiert.
                            Den String "Ziffer" für Ziffer (also ZehnerStunde, EinerStunde, ZehnerMinute, EinerMinute, ZehnerSekunde, EinerSekunde) in Variablen überführt.
                            Dann stellenweise addiert und ggf. Überträge verrechnet.
                            Dann den String mit der korrekten Zeitdauer konvertiert nach Datum/Zeit.

                            Das funktioniert, aaaber: Geht das nicht leichter/einfacher/schneller?
                            Besteht keine Möglichkeit zwei Datenpunkte der Form SS:MM:ss zu addieren, sodass das Ergebnis ebenfalls das Format SS:MM:ss hat?

                            paul53 1 Reply Last reply Reply Quote 0
                            • paul53
                              paul53 @Matthias I last edited by

                              @matthias-i sagte: Geht das nicht leichter/einfacher/schneller?

                              Ja.

                              @matthias-i sagte in Zeitdifferenz berechnen:

                              Besteht keine Möglichkeit zwei Datenpunkte der Form SS:MM:ss zu addieren, sodass das Ergebnis ebenfalls das Format SS:MM:ss hat?

                              Man kann nur Zahlen addieren, keine Strings.

                              M 1 Reply Last reply Reply Quote 0
                              • M
                                Matthias I @paul53 last edited by

                                @paul53 Wie kann man das realisieren?
                                Wenn ich dich richtig verstehe müsste man ja dann SS:MM:ss je zu einer Zahl konvertieren, dann die Addition vornehmen und dann von Zahl wieder zu SS:MM:ss konvertieren? Könntest du mir sagen, wie das geht?

                                1 Reply Last reply Reply Quote 0
                                • paul53
                                  paul53 @Matthias I last edited by paul53

                                  @matthias-i sagte: Mein Plan ist deshalb den Zeitplan des Mähroboters zu erweitern, ihn aber nur dann mähen zu lassen, wenn die wöchentliche max. Mähzeit nicht überschritten ist und ihn bei unterschreiten einer minimalen Mähzeit am Wochenende auch außerhalb des Zeitplans mähen zulassen, um "Mähzeit nachzuholen".

                                  Der Aussage entnehme ich, dass es um die wöchentliche Mäh-Dauer geht? Das Prinzip der Kumulation der Mäh-Dauer habe ich schon hier gezeigt (es wird mit ms gerechnet). Einmal in der Woche muss dann per Zeitplan die Mäh-Dauer zurück gesetzt werden. Unter der Woche kann die schon erreichte Mäh-Dauer ausgewertet werden.

                                  Bild_2021-03-06_141139.png

                                  M E 2 Replies Last reply Reply Quote 0
                                  • M
                                    Matthias I @paul53 last edited by

                                    @paul53 Vielen Dank für die schnelle Antwort!
                                    Es geht mir auch darum, zu verstehen, wie man mit Datenpunkten des Formates SS:MM:ss rechnen kann.
                                    Auch bei der Ladezeit des E-Autos möchte ich gerne Zeiten auf diese Weise berechnen.
                                    Zusammenfassen kann man also sagen, dass SS:MM:ss in Millisekunden umgewandelt werden muss, dann kann man mit dem Wert (als Zahl) rechnen und wandelt das ganze anschließend wieder in das gewünschte Datum-/Zeitformat wie z.B. SS:MM:ss um, richtig?

                                    paul53 1 Reply Last reply Reply Quote 0
                                    • paul53
                                      paul53 @Matthias I last edited by paul53

                                      @matthias-i sagte: SS:MM:ss in Millisekunden umgewandelt werden muss

                                      Eine Zeitdifferenz in "hh:mm:ss" muss so gewandelt werden, damit mit der Differenz in ms weiter gerechnet werden kann:

                                      Bild_2021-03-06_141939.png

                                      N 1 Reply Last reply Reply Quote 0
                                      • S
                                        Strobi last edited by Strobi

                                        Ich möchte nicht unbedingt ein neues Thema eröffnen - ich hoffe, mein Anliegen passt hier rein.
                                        Ich würde gerne die Zeitdifferenz (Minutengenau bzw Stundengenau (als Kommazahl) würde ausreichen) der aktuellen Tageszeit bis zum Sonnenuntergang und Sonnenaufgang berechnen.

                                        Habt Ihr eine Idee, ob / wie das möglich ist?

                                        Besten Dank im Voraus

                                        paul53 1 Reply Last reply Reply Quote 0
                                        • paul53
                                          paul53 @Strobi last edited by

                                          @strobi sagte: Stundengenau (als Kommazahl) würde ausreichen) der aktuellen Tageszeit bis zum Sonnenuntergang

                                          Bild_2021-11-25_200531.png

                                          S D 2 Replies Last reply Reply Quote 1
                                          • N
                                            newbie2007 @paul53 last edited by

                                            @paul53 Hallo,

                                            ich möchte gerne die Laufzeit meines Roombas mit Hilfe der Start- und der Endzeit berechnen und habe folgendes Blockly gemacht. Allerdings wird die Differenz/Laufzeit nicht korrekt berechnet. Die berechnete Dauer ist im Bsp. 2St. 16min. Tatsächlich sind es aber 1 Std. und 16 min.
                                            Wer kann mir helfen?
                                            5FA0B048-D03C-4567-BEE6-2ECC6B858C0B.jpeg

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            404
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            blockly
                                            16
                                            89
                                            13746
                                            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