Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. asynch funktion

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    16
    1
    1.9k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    906

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

asynch funktion

Geplant Angeheftet Gesperrt Verschoben JavaScript
29 Beiträge 6 Kommentatoren 924 Aufrufe 4 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • D Delphinis

    @codierknecht
    @paul53
    Ihr habt ja alle recht, dass das nicht super akkurat ist, mit den 500ms. Aber die Werte kommen bei mir innerhalb von 120ms +/-20ms rein und da ich bin ja nur im Lan und nicht im Internet. Aber klar, garantiert ist das natürlich nicht und es könnte sein, dass das mal falsch ist. Mit dieser Ungenauigkeit könnte ich aber leben.
    Ich möchte aber eben auch nicht alle 10 Sekunden 5 verschiedene Werte, welche alle fast gleichzeitig reinkommen. Das ist auch nicht akkurat für eine Statistik und füllt mir nur den Speicher.

    Vielleicht gibt es ja etwas was nur einmal triggert, nachdem alle fünf reingekommen sind?

    Aber im Moment übernehme ich mal die Version von @haus-automatisierung. Die funktioniert schon mal recht gut. Die von @paul53 würde wahrscheinlich auch tun.

    Das Problem ist halt, dass nicht alle States immer reinkommen, wenn es keine Änderung gibt, weshalb ich auf diesen (in diesem Fall der Erste) State triggern will. Dies wiederum wiederspricht dann auch meiner obigen Überlegung einen Trigger auf alle fünf zu legen.

    paul53P Offline
    paul53P Offline
    paul53
    schrieb am zuletzt editiert von
    #16

    @delphinis sagte: nicht alle States immer reinkommen, wenn es keine Änderung gibt,

    Deshalb sollte auf "Aktualisierung" getriggert werden. Der Modbus-Adapter aktualisiert hoffentlich Werte, die 0 sind?

    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

    D 1 Antwort Letzte Antwort
    0
    • paul53P paul53

      @delphinis sagte: nicht alle States immer reinkommen, wenn es keine Änderung gibt,

      Deshalb sollte auf "Aktualisierung" getriggert werden. Der Modbus-Adapter aktualisiert hoffentlich Werte, die 0 sind?

      D Offline
      D Offline
      Delphinis
      schrieb am zuletzt editiert von
      #17

      @paul53 said in asynch funktion:

      Deshalb sollte auf "Aktualisierung" getriggert werden. Der Modbus-Adapter aktualisiert hoffentlich Werte, die 0 sind?

      Ja stimmt, das kann man einstellen.

      1 Antwort Letzte Antwort
      0
      • PeoplesP Peoples

        @haus-automatisierung

        du liest die Werte doch nach einer gewissen zeit ein, ich beziehe sie async. D.H. eigentlich wenn die Werte bei dir nicht innerhalb von 500ms zur Verfügung stehen fehlen sie, bei mir wird gewartet bis sie vorhanden sind. Oder habe ich da einen Denkfehler drin?

        paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von
        #18

        @peoples sagte: bei mir wird gewartet bis sie vorhanden sind.

        Werte sind immer vorhanden, was nicht bedeutet, dass sie zeitlich zusammen gehören.

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

        PeoplesP 1 Antwort Letzte Antwort
        0
        • paul53P paul53

          @peoples sagte: bei mir wird gewartet bis sie vorhanden sind.

          Werte sind immer vorhanden, was nicht bedeutet, dass sie zeitlich zusammen gehören.

          PeoplesP Offline
          PeoplesP Offline
          Peoples
          schrieb am zuletzt editiert von
          #19

          @paul53

          Da hast du auch wieder recht

          Ich beantworte keine Fragen zu Themen via PN

          D 1 Antwort Letzte Antwort
          0
          • PeoplesP Peoples

            @paul53

            Da hast du auch wieder recht

            D Offline
            D Offline
            Delphinis
            schrieb am zuletzt editiert von Delphinis
            #20

            @peoples
            @Codierknecht
            @haus-automatisierung
            @paul53
            So, habe es jetzt so realisiert: Ich triggere auf die wichtigsten Ereignisse, lasse das Script aber nach dem Singleton ansatz nur einmal laufen. So hab ich aktuelle Werte, ohne dass das Script zig mal durchläuft. Die Zeit von 500ms sollte dazu dicke reichen, und wenn das einmal nicht klappen sollte, ist es auch egal. Aber ich bin ja nicht im Internet wo die Packete über zig ruoter rüber müssen. So glaube ich dass das für 99.9% aller Fälle reicht. Und wenn nicht, ist es auch kein Unglück.
            Jedenfalls kommen die Werte jetzt korrekt verrechnet und immer nur einer. Die Debug infos nehm ich natürlich wieder raus.

            if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
            createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
            }
            
            var count = 0;
            var count2 = 0;
            var working = false;
            const ids = ['modbus.0.inputRegisters.30775_Messwert_Leistung',     // parameter auf die getriggert werden
                         'modbus.0.inputRegisters.30865_Leistung_Bezug',
                         'modbus.0.inputRegisters.31395_Batterieentladung',
                         'modbus.0.inputRegisters.30867_Messwert_Leistung_Einspeisung'];    
            
            
            // On change
            //on('modbus.0.inputRegisters.30775_Messwert_Leistung', async (data) => {
            on(ids, async (data) => {
                count+=1;
                if (working == false) {
                    working = true;
                    count2+=1;
                    const now1 = new Date();
                    const minutes1 = now1.getMinutes();
                    const seconds1 = now1.getSeconds();
                    const millis1 = now1.getMilliseconds();
            
                    await wait(500);
            
                    const WR = getState('modbus.0.inputRegisters.30775_Messwert_Leistung').val;
                    const Bezug = getState('modbus.0.inputRegisters.30865_Leistung_Bezug').val;
                    const Einspeisung = getState('modbus.0.inputRegisters.30867_Messwert_Leistung_Einspeisung').val;
                    const BatLad = getState('modbus.0.inputRegisters.31393_Batterieladung').val;
                    const BatEntl = getState('modbus.0.inputRegisters.31395_Batterieentladung').val;
            
                    let eigenverbrauch = (WR + Bezug - Einspeisung - BatLad/* + BatEntl*/);
                    setState('0_userdata.0.Solar.Leistung.Eigenverbrauch', eigenverbrauch, true);
            
                    const now2 = new Date();
                    const minutes2 = now2.getMinutes();
                    const millis2 = now2.getMilliseconds();
                    const seconds2 = now2.getSeconds();
                    console.log(count + ' ' + count2 + ` start:${minutes1}:${seconds1}:${millis1}. ` + `time:${minutes2}:${seconds2}:${millis2} - ` + eigenverbrauch);
                    working = false;
                }
            });
            
            

            Danke an alle, ich habe wieder einiges gelernt :-)

            1 Antwort Letzte Antwort
            0
            • CodierknechtC Codierknecht

              @haus-automatisierung

              werden die Register ja der Reihe nach abgefragt

              Das würde bedeuten, dass man das auch selbst in der Hand hat.
              Triggert man auf den state, der als letztes gelesen wird, braucht's auch keinen timeout.

              Werde ich mich wohl demnächst auch mal mit beschäftigen müssen.
              Meine PV kommt Montag ;-)

              D Offline
              D Offline
              Delphinis
              schrieb am zuletzt editiert von
              #21

              @codierknecht said in asynch funktion:

              Werde ich mich wohl demnächst auch mal mit beschäftigen müssen.
              Meine PV kommt Montag

              Was hast du denn für einen WR? Falls du SMA hast, könnten wir uns ja vielleicht dann mal austauschen, das Berechnen des Eigenverbrauchst ist nämlich gar nicht so einfach, wie ich jetzt gemerkt hab. Vielleicht kann ich ja mal was beitragen...

              CodierknechtC haus-automatisierungH 2 Antworten Letzte Antwort
              0
              • D Delphinis

                @codierknecht said in asynch funktion:

                Werde ich mich wohl demnächst auch mal mit beschäftigen müssen.
                Meine PV kommt Montag

                Was hast du denn für einen WR? Falls du SMA hast, könnten wir uns ja vielleicht dann mal austauschen, das Berechnen des Eigenverbrauchst ist nämlich gar nicht so einfach, wie ich jetzt gemerkt hab. Vielleicht kann ich ja mal was beitragen...

                CodierknechtC Offline
                CodierknechtC Offline
                Codierknecht
                Developer Most Active
                schrieb am zuletzt editiert von
                #22

                @delphinis sagte in asynch funktion:

                Was hast du denn für einen WR

                Q.HOME⁺ ESS HYB-G3

                "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                HmIP|ZigBee|Tasmota|Unifi
                Zabbix Certified Specialist
                Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                1 Antwort Letzte Antwort
                0
                • D Delphinis

                  @codierknecht said in asynch funktion:

                  Werde ich mich wohl demnächst auch mal mit beschäftigen müssen.
                  Meine PV kommt Montag

                  Was hast du denn für einen WR? Falls du SMA hast, könnten wir uns ja vielleicht dann mal austauschen, das Berechnen des Eigenverbrauchst ist nämlich gar nicht so einfach, wie ich jetzt gemerkt hab. Vielleicht kann ich ja mal was beitragen...

                  haus-automatisierungH Online
                  haus-automatisierungH Online
                  haus-automatisierung
                  Developer Most Active
                  schrieb am zuletzt editiert von
                  #23

                  @delphinis sagte in asynch funktion:

                  Eigenverbrauchst ist nämlich gar nicht so einfach, wie ich jetzt gemerkt hab

                  Ist ja auch technisch fast unmöglich. Du müsstest ja jedes Mal zeitgleich alle Werte bekommen. Bei mir sind Zähler, PV-Wechselrichter und Wallbox getrennte Geräte. Batterie-Inverter kommt noch getrennt dazu. Das heißt, man wird nie eine Momentaufnahme bekommen, welche Dir genau einen richtigen Wert liefern kann. Die Messintervalle und wie oft über Modbus die Daten abgefragt werden, ist ja bei jedem Gerät anders.

                  Also einfach alles in die Datenbank loggen. Dann kannst Du damit aggregiert in einem 5, 10 oder 15min Fenster rechnen. Und für Energiedaten funktioniert das bei mir sehr genau. Eine gewisse Unschärfe ist immer drin. Sonst müsste man ja im Millisekunden-Bereich Daten bekommen.

                  🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                  🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                  📚 Meine inoffizielle ioBroker Dokumentation

                  1 Antwort Letzte Antwort
                  0
                  • CodierknechtC Offline
                    CodierknechtC Offline
                    Codierknecht
                    Developer Most Active
                    schrieb am zuletzt editiert von
                    #24

                    @delphinis
                    Nur ein paar Kleinigkeiten.
                    Ich weiß: Erbsenzählerei, aber da bin ich manchmal etwas penibel.

                    • Zeile 2 sollte eingerückt werden
                    • Statt if (working == false) kann man auch if (!working) schreiben
                    • Ein count+=1 notiert man üblicherweise count++

                    Auf sowas reite ich gerne mal rum ;-)
                    Code wird zu 80% gelesen und nicht geschrieben. Und dabei geht es nicht nur um fremde Leser.
                    Nicht selten sitzt man nach Tagen, Wochen oder Monaten vor einem Stück Code und fragt sich: "Welcher Vollhorst hat das denn verbrochen?"
                    Nur um nach einiger Zeit festzustellen: "Uuuups, war ich ja selbst!"

                    Die Formatierung der Zeit lässt sich auch noch vereinfachen.

                    const moment = require('moment');
                    
                    const now1 = moment().format('mm:ss:SSS');
                    
                    

                    Warum selbst zusammenklöppeln, wenn es dafür schon passende Bibliotheken gibt? ;-)

                    "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                    Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                    HmIP|ZigBee|Tasmota|Unifi
                    Zabbix Certified Specialist
                    Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                    haus-automatisierungH 1 Antwort Letzte Antwort
                    0
                    • CodierknechtC Codierknecht

                      @delphinis
                      Nur ein paar Kleinigkeiten.
                      Ich weiß: Erbsenzählerei, aber da bin ich manchmal etwas penibel.

                      • Zeile 2 sollte eingerückt werden
                      • Statt if (working == false) kann man auch if (!working) schreiben
                      • Ein count+=1 notiert man üblicherweise count++

                      Auf sowas reite ich gerne mal rum ;-)
                      Code wird zu 80% gelesen und nicht geschrieben. Und dabei geht es nicht nur um fremde Leser.
                      Nicht selten sitzt man nach Tagen, Wochen oder Monaten vor einem Stück Code und fragt sich: "Welcher Vollhorst hat das denn verbrochen?"
                      Nur um nach einiger Zeit festzustellen: "Uuuups, war ich ja selbst!"

                      Die Formatierung der Zeit lässt sich auch noch vereinfachen.

                      const moment = require('moment');
                      
                      const now1 = moment().format('mm:ss:SSS');
                      
                      

                      Warum selbst zusammenklöppeln, wenn es dafür schon passende Bibliotheken gibt? ;-)

                      haus-automatisierungH Online
                      haus-automatisierungH Online
                      haus-automatisierung
                      Developer Most Active
                      schrieb am zuletzt editiert von haus-automatisierung
                      #25

                      @codierknecht sagte in asynch funktion:

                      Warum selbst zusammenklöppeln, wenn es dafür schon passende Bibliotheken gibt?

                      Und wozu Bibliotheken einbinden, wenn das gleiche mit Date (bzw. Intl) auch schon funktioniert? :)

                      new Date().toLocaleTimeString('de-DE', { minute: '2-digit', second: '2-digit', fractionalSecondDigits: 3 })
                      

                      oder die integrierten Funktionen des JavaScript-Adapters:

                      formatDate(new Date(), 'mm:ss.sss');
                      

                      🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                      🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                      📚 Meine inoffizielle ioBroker Dokumentation

                      CodierknechtC 2 Antworten Letzte Antwort
                      0
                      • haus-automatisierungH haus-automatisierung

                        @codierknecht sagte in asynch funktion:

                        Warum selbst zusammenklöppeln, wenn es dafür schon passende Bibliotheken gibt?

                        Und wozu Bibliotheken einbinden, wenn das gleiche mit Date (bzw. Intl) auch schon funktioniert? :)

                        new Date().toLocaleTimeString('de-DE', { minute: '2-digit', second: '2-digit', fractionalSecondDigits: 3 })
                        

                        oder die integrierten Funktionen des JavaScript-Adapters:

                        formatDate(new Date(), 'mm:ss.sss');
                        
                        CodierknechtC Offline
                        CodierknechtC Offline
                        Codierknecht
                        Developer Most Active
                        schrieb am zuletzt editiert von
                        #26

                        @haus-automatisierung
                        Punkt für Dich :grin:

                        "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                        Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                        HmIP|ZigBee|Tasmota|Unifi
                        Zabbix Certified Specialist
                        Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                        1 Antwort Letzte Antwort
                        0
                        • haus-automatisierungH haus-automatisierung

                          @codierknecht sagte in asynch funktion:

                          Warum selbst zusammenklöppeln, wenn es dafür schon passende Bibliotheken gibt?

                          Und wozu Bibliotheken einbinden, wenn das gleiche mit Date (bzw. Intl) auch schon funktioniert? :)

                          new Date().toLocaleTimeString('de-DE', { minute: '2-digit', second: '2-digit', fractionalSecondDigits: 3 })
                          

                          oder die integrierten Funktionen des JavaScript-Adapters:

                          formatDate(new Date(), 'mm:ss.sss');
                          
                          CodierknechtC Offline
                          CodierknechtC Offline
                          Codierknecht
                          Developer Most Active
                          schrieb am zuletzt editiert von
                          #27

                          @haus-automatisierung sagte in asynch funktion:

                          oder die integrierten Funktionen des JavaScript-Adapters:

                          Genau danach hatte ich gesucht, war aber zu blöd es zu finden :-(

                          "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                          Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                          HmIP|ZigBee|Tasmota|Unifi
                          Zabbix Certified Specialist
                          Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                          haus-automatisierungH 1 Antwort Letzte Antwort
                          0
                          • CodierknechtC Codierknecht

                            @haus-automatisierung sagte in asynch funktion:

                            oder die integrierten Funktionen des JavaScript-Adapters:

                            Genau danach hatte ich gesucht, war aber zu blöd es zu finden :-(

                            haus-automatisierungH Online
                            haus-automatisierungH Online
                            haus-automatisierung
                            Developer Most Active
                            schrieb am zuletzt editiert von
                            #28

                            @codierknecht https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#formatdate

                            🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                            🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                            📚 Meine inoffizielle ioBroker Dokumentation

                            CodierknechtC 1 Antwort Letzte Antwort
                            0
                            • haus-automatisierungH haus-automatisierung

                              @codierknecht https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#formatdate

                              CodierknechtC Offline
                              CodierknechtC Offline
                              Codierknecht
                              Developer Most Active
                              schrieb am zuletzt editiert von
                              #29

                              @haus-automatisierung
                              Da war ich tatsächlich schon.
                              Hatte aber nach sowas wie "formatTime()" gesucht und bin dann bei "formatTimeDiff()" gelandet.

                              Ein bisschen hochscrollen hätte das Problem gelöst.
                              Manchmal ist es soooooo einfach :grin:

                              "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                              Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                              HmIP|ZigBee|Tasmota|Unifi
                              Zabbix Certified Specialist
                              Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                              1 Antwort Letzte Antwort
                              0
                              Antworten
                              • In einem neuen Thema antworten
                              Anmelden zum Antworten
                              • Älteste zuerst
                              • Neuste zuerst
                              • Meiste Stimmen


                              Support us

                              ioBroker
                              Community Adapters
                              Donate

                              699

                              Online

                              32.6k

                              Benutzer

                              82.2k

                              Themen

                              1.3m

                              Beiträge
                              Community
                              Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                              ioBroker Community 2014-2025
                              logo
                              • Anmelden

                              • Du hast noch kein Konto? Registrieren

                              • Anmelden oder registrieren, um zu suchen
                              • Erster Beitrag
                                Letzter Beitrag
                              0
                              • Home
                              • Aktuell
                              • Tags
                              • Ungelesen 0
                              • Kategorien
                              • Unreplied
                              • Beliebt
                              • GitHub
                              • Docu
                              • Hilfe