Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Wie viel Tage bis Termin

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    Wie viel Tage bis Termin

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

      Hallo,

      ich probiere mich grad dumm und dämlich.
      Aber irgendwie will es nicht wie ich.

      Ich würde gerne ausrechnen, wie viele Tage es noch bis zu einem Termin sind.

      Allerdings nicht absolut sondern relativ (keine Ahnung ob das die richtige Beschreibung ist 😅).

      Wenn wir jetzt 23 Uhr haben und ich morgen früh um 0:30 Uhr einen Termin habe soll 1 raus kommen. Wenn der Termin morgen um kurz vor Mitternacht ist auch.
      Übermorgen dann eine 2, egal welche Uhrzeit.
      Wenn der Termin noch heute ist soll das Ergebniss 0 sein.

      paul53 OliverIO 2 Replies Last reply Reply Quote 0
      • mickym
        mickym Most Active last edited by mickym

        @david-g Im Prinzip brauchst doch eigentlich nur den timestamp vom Termin und die aktuelle Zeit. Beides normierst Du auf Tagesanfang. Die Differenz teilst Du durch die Länge eines Tages.

        Wenn Du egal welche Uhrzeit einfach nur das Datum eingibst bei der Erstellung eines Date Objektes:

        const d = new Date(2018, 11, 24);
        

        dann bekommst immer die Zeit um 0:00. 🙂

        Sprich heute

        const d = new Date(2021, 08, 06);
        

        morgen:

        const t = new Date(2021, 08, 07);
        

        Da beide Uhrzeiten ignoriert werden, vergleichst Du bei Deinem Beispiel:

        23 Uhr haben und ich morgen früh um 0:30 Uhr einen Termin habe soll 1

        im Prinzip die Zeitspanne von heute um 0:00 mit morgen 0:00. Die Differenz ist dann vom timestamp immer der Unterschied von:

        1000 * 60 * 60 * 24 =86.400.000

        Wenn Du also die Differenz Math.floor(Diff/86.400.000), sollte die gewünschte Zahl rauskommen.

        Im Prinzip geht bei der Date Erstellung auch die amerikanische Schreibweise mit String:

        4e7a7095-2016-4f6d-a855-daea29da3ae6-image.png

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

          @mickym

          Danke für die Antwort.
          Bekommt man sowas auch in Blockly hin?
          In JS bin ich nicht wirklich fit.

          Hab schon ein (für mich) recht umfangreiches Skript wo ich es gerne einbauen würde.

          Der Termin in der Zukunft liegt im ical Adapter als Datumsobjekt mit Zeit vor.

          EDIT:
          Ich glaube ich habe es hinbekommen.
          Deine Rechnung konnte ich mit Konvertierungen nachvollziehen.

          Screenshot_20210806-215021_Chrome.jpg

          Oder sieht da jemand einen Fehler?
          Gerundet habe ich, da immer ein 0,09.... rausgekommen ist. Vermutlich die Zeit die das script läuft.

          mickym 1 Reply Last reply Reply Quote 0
          • mickym
            mickym Most Active @David G. last edited by

            @david-g Ich bin kein blockly Spezialist und bevor ich mir wieder einen abringe, da ist @paul53 schneller. 😉

            Wichtig ist bei der Differenzberechnung, dass das Datum aktuell und das Datum des Termins halt immer auf 0:00 normiert werden. Das kann ich an dem Blockly nicht erkennen.

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

              @mickym

              Hab ich auch probiert.
              Aber nicht gefunden.

              Geht um eine Wochenübersicht in telegram.
              Hab hinter den Termin zum testen das Ergebnis der Formel gepackt (noch ohne Runden und das +1).
              Screenshot_20210806-221926_Telegram.jpg

              Mehrere der Termine haben komplett verschiedene Uhrzeiten. Dafür finde ich die Nachkommastellen zu identisch, wie das es nicht stimmt.....

              mickym 1 Reply Last reply Reply Quote 0
              • mickym
                mickym Most Active @David G. last edited by

                @david-g Ich hab den Adapter nicht im Einsatz und bin wie gesagt nicht der Blockly-Typ - aber ich werde mir mal den Adapter installieren. Bin ja auch Apple User. 😉

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

                  @mickym

                  Der Name des ical Adapters ist irreführend finde ich.
                  Hab ihn lange nicht installiert, da ich dachte er wäre eben für ical von Apple.

                  Ich nutze den Adapter mit Gmail und hab keinen Apple Gerät ^^.

                  Wird verschiedenes unterstützt.

                  mickym 2 Replies Last reply Reply Quote 0
                  • mickym
                    mickym Most Active @David G. last edited by

                    @david-g Ok - konnte trotzdem meinen Apple Kalender einbinden. Unter data bekomme ich meine Termine angezeigt.

                    Unter events sehe ich nichts. Wie sehen denn Deine Terminobjekte aus?

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

                      @david-g sagte: ausrechnen, wie viele Tage es noch bis zu einem Termin sind.

                      In welchem Format liegt der Termin vor?

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

                        @paul53
                        @mickym

                        Die Termine sehen so aus.
                        Hole ich in Blockly mit einer Schleife

                        {'date':'11.08.2021  ','event':'Dr. Xxx','_class':'ical_Termine ','_date':'2021-08-10T22:00:00.000Z','_end':'2021-08-11T22:00:00.000Z','_section':'','_IDID':'xxxxxxx@google.com','_allDay':true,'_rule':' ','location':'','_calName':'Termine','_calColor':'#000000'}
                        

                        Ich verwende das

                        _date
                        
                        paul53 1 Reply Last reply Reply Quote 0
                        • mickym
                          mickym Most Active @David G. last edited by

                          @david-g Ich bekomme als Termin in einem Array nur dieses Format:

                          {"date":"Morgen 22:00-23:00","event":"Testtermin","_class":"ical_calendar1 ical_tomorrow","_date":"2021-08-07T20:00:00.000Z","_end":"2021-08-07T21:00:00.000Z","_IDID":"54E24963-51C8-47AF-AEC0-642F6BA1525D","_allDay":false,"_private":false,"_rule":" ","location":"","_calName":"calendar1","_calColor":"#000000"}
                          

                          in dem table Datenpunkt:

                          Meinst Du dann dieses Datumsformat:

                          2021-08-07T20:00:00.000Z
                          

                          Dann brauchst nur den vorderen Teil bist zum T und Du hast das ISO Format:

                          a88761e3-a02d-46d5-91a3-c57e6fb44f2b-image.png

                          Aber nachdem @paul53 eh schon involviert ist, weiß er sicher wie man diese beiden Datumsobjekte erstellt. 😉

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

                            @david-g

                            die Lösung inklusive vis widgets findest du im mytime-adapter.
                            das einfachste wäre das countdown plain widget, das dir schön runterzählt wieviel jahre,tage,monate,stunden es noch dauert. du definierst einmal in der adapter konfiguration die dauer.
                            über einen befehlssyntax in einem bestimmten datenpunkt kannst du auch einen absoluten zeitpunkt in der zukunft definieren

                            https://github.com/oweitman/iobroker.mytime

                            Der Adapter ist auch im beta/latest repository verfügbar.

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

                              @mickym

                              Genau, das meine ich.

                              @OliverIO
                              Probiere in meinen Skripten immer so wenig andere Adapter einzubinden wie nötig.
                              Es geht auch nicht um die VIS. Geht um eine Terminübersicht der kommenden Woche die ich per telegram versende. Über die Tage ermitteln ich die Termine für diesen Zeitraum.

                              OliverIO mickym 2 Replies Last reply Reply Quote 0
                              • paul53
                                paul53 @David G. last edited by paul53

                                @david-g sagte: Ich verwende das

                                _date
                                

                                Ich vermute, als Uhrzeit steht dort im Sommer immer "22:00:00.000Z"? Dann sollte es so funktionieren:

                                Bild_2021-08-06_232352.png

                                Anstelle des Datenpunktwertes habe ich einen String mit dem Wert von _date eingetragen.

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

                                  @david-g sagte in Wie viel Tage bis Termin:

                                  @mickym

                                  Genau, das meine ich.

                                  @OliverIO
                                  Probiere in meinen Skripten immer so wenig andere Adapter einzubinden wie nötig.
                                  Es geht auch nicht um die VIS. Geht um eine Terminübersicht der kommenden Woche die ich per telegram versende. Über die Tage ermitteln ich die Termine für diesen Zeitraum.

                                  ok dann so

                                  (new Date("01/03/2021") - new Date()) / 86400000

                                  (Datum Zukunft - aktuelles Datum ) / Anzahl Millisekunden an einem Tag

                                  Dein blocklyansatz sieht gut aus, bin da aber etwas lost.
                                  Die Differenz kommt evtl daher, das wenn du das Datum so wie ich angegeben hast, immer 00:00 Uhr gemeint ist.

                                  die abarbeitung solch eines Befehls dauert auf meinem System ca 2 Millisekunden. Da dürfte keine solche Differenz von 0.09 Tagen ergeben.

                                  1 Reply Last reply Reply Quote 0
                                  • mickym
                                    mickym Most Active @David G. last edited by mickym

                                    @david-g

                                    7e55d197-b273-49ba-ab69-d319f36800d5-image.png

                                    Also ich habs mit Z+2 hinbekommen, wenn man den ISO String benutzt.

                                    Das Datum alleine nutzt nichts - weil irgendwas die Timezone dazurechnet und dann kommt immer 2:00 Uhr früh raus.

                                    Ich schau mal ob irgendwas mit CET funktioniert, da absolute Zeitoffsets ja blöde sind.

                                    paul53 mickym 2 Replies Last reply Reply Quote 0
                                    • paul53
                                      paul53 @mickym last edited by

                                      @mickym sagte: Also ich habs mit Z+2 hinbekommen, wenn man den ISO String benutzt-

                                      Dann stimmt es aber nur zur Sommerzeit.

                                      1 Reply Last reply Reply Quote 0
                                      • mickym
                                        mickym Most Active @mickym last edited by mickym

                                        @mickym

                                        @paul53 sagte in Wie viel Tage bis Termin:

                                        @mickym sagte: Also ich habs mit Z+2 hinbekommen, wenn man den ISO String benutzt-

                                        Dann stimmt es aber nur zur Sommerzeit.

                                        Dann gibt man das einfach fix ein - das geht: Also aus dem Datestring den vorderen Teil vor dem T abschneiden und dann T00:00 anhängen.

                                        bbf71b09-b68b-4e22-9bc5-b575b89758a3-image.png

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

                                          @mickym

                                          Das habe ich beim rechnen mal probiert.

                                          Hatte zu DD.MM.JJJJ konvertiert für das aktuelle Datum und den Termin, mit der Hoffnung dass dann die Uhrzeit ignoriert wird.

                                          Wenn ich dann Termin-Uhrzeit rechne kommt NaN als Ergebniss.

                                          mickym paul53 3 Replies Last reply Reply Quote 0
                                          • mickym
                                            mickym Most Active @David G. last edited by mickym

                                            @david-g Ich habs bald. 😉 - bin halt als Blockly Laie etc. langsam - aber ich denke bin auf gutem Weg.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            850
                                            Online

                                            32.0k
                                            Users

                                            80.5k
                                            Topics

                                            1.3m
                                            Posts

                                            4
                                            26
                                            957
                                            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