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
    911

  • 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

    Hallo,
    ich möchte in einer Funktion in der ich Werte verrechne, warten, bis alle Werte eingetrudelt sind. Für "wait" muss ich ja offensichtlich eine asynch function verwenden. In den Java Scripts fehlt ja aber der Funktionskopf.
    Ich habs mal so versucht:

    async function Eigenverbrauch {
        // On change
        on('modbus.0.inputRegisters.30775_Messwert_Leistung', (data) => {
            
            if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
            createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
            }
    
            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);
        });
    }
    

    dies liefert aber den Fehler:

    15:16:36.440	error	javascript.0 (8848) script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch compile failed: at script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch:1
    

    Wie kann man das realisieren?

    Btw: gibt es da irgendwo genauere Fehlermeldungen beim compilieren?

    ? Offline
    ? Offline
    Ein ehemaliger Benutzer
    schrieb am zuletzt editiert von
    #2

    @delphinis da fehlt die klammer in der ersten Zeile hinter ‚async function Eigenverbrauch‘

    Muss so aussehen:

    async function Eigenverbrauch() {
    
    1 Antwort Letzte Antwort
    1
    • D Delphinis

      Hallo,
      ich möchte in einer Funktion in der ich Werte verrechne, warten, bis alle Werte eingetrudelt sind. Für "wait" muss ich ja offensichtlich eine asynch function verwenden. In den Java Scripts fehlt ja aber der Funktionskopf.
      Ich habs mal so versucht:

      async function Eigenverbrauch {
          // On change
          on('modbus.0.inputRegisters.30775_Messwert_Leistung', (data) => {
              
              if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
              createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
              }
      
              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);
          });
      }
      

      dies liefert aber den Fehler:

      15:16:36.440	error	javascript.0 (8848) script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch compile failed: at script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch:1
      

      Wie kann man das realisieren?

      Btw: gibt es da irgendwo genauere Fehlermeldungen beim compilieren?

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

      @delphinis
      1.) Du kannst keinen Trigger in eine Funktion packen.

      2.)

      bis alle Werte eingetrudelt sind

      Wann soll das sein? Meinst Du die 500 ms? Das kann passen, muss aber nicht. Kommt drauf an auf was Du da warten willst.

      Wenn Dein Ergebnis aus 5 Werten besteht, solltest Du auf alle 5 DP triggern.
      Bei jeder einzelnen Änderung ergibt sich ein anderes Ergebnis.

      "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
      1
      • D Delphinis

        Hallo,
        ich möchte in einer Funktion in der ich Werte verrechne, warten, bis alle Werte eingetrudelt sind. Für "wait" muss ich ja offensichtlich eine asynch function verwenden. In den Java Scripts fehlt ja aber der Funktionskopf.
        Ich habs mal so versucht:

        async function Eigenverbrauch {
            // On change
            on('modbus.0.inputRegisters.30775_Messwert_Leistung', (data) => {
                
                if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
                createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
                }
        
                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);
            });
        }
        

        dies liefert aber den Fehler:

        15:16:36.440	error	javascript.0 (8848) script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch compile failed: at script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch:1
        

        Wie kann man das realisieren?

        Btw: gibt es da irgendwo genauere Fehlermeldungen beim compilieren?

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

        @delphinis sagte in asynch funktion:

        dies liefert aber den Fehler:

        Naja dein await wait(500); ist ja auch nicht Teil der Funktion Eigenverbrauch, sondern wird im Callback aufgerufen (die anonyme Funktion des Triggers), welche nicht als async definiert ist.

        Aber wie @Codierknecht schon sagte, würdest Du so mit jedem Funktionsaufruf eh einen neuen Trigger erstellen. Das ist keine gute Idee. Du suchst ggf. sowas:

        if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
            createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
        }
        
        on('modbus.0.inputRegisters.30775_Messwert_Leistung', async (data) => {
            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;
        
            const eigenverbrauch = WR + Bezug - Einspeisung -BatLad + BatEntl;
            setState('0_userdata.0.Solar.Leistung.Eigenverbrauch', eigenverbrauch, true);
        });
        

        🧑‍🎓 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
        1
        • D Delphinis

          Hallo,
          ich möchte in einer Funktion in der ich Werte verrechne, warten, bis alle Werte eingetrudelt sind. Für "wait" muss ich ja offensichtlich eine asynch function verwenden. In den Java Scripts fehlt ja aber der Funktionskopf.
          Ich habs mal so versucht:

          async function Eigenverbrauch {
              // On change
              on('modbus.0.inputRegisters.30775_Messwert_Leistung', (data) => {
                  
                  if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
                  createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
                  }
          
                  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);
              });
          }
          

          dies liefert aber den Fehler:

          15:16:36.440	error	javascript.0 (8848) script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch compile failed: at script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch:1
          

          Wie kann man das realisieren?

          Btw: gibt es da irgendwo genauere Fehlermeldungen beim compilieren?

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

          @delphinis sagte: warten, bis alle Werte eingetrudelt sind.

          Dann nimm setTimeout().

          if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
              createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: false, role: 'value'});
          }
          
          on({id: 'modbus.0.inputRegisters.30775_Messwert_Leistung'}, (data) => {
              const WR = data.state.val;
              setTimeout(function() {
                  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;
           
                  const eigenverbrauch = WR + Bezug - Einspeisung - BatLad + BatEntl;
                  setState('0_userdata.0.Solar.Leistung.Eigenverbrauch', eigenverbrauch, true);
              }, 500);
          });
          

          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

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

            Mal eben so hingeschrieben:

            const ids = ['modbus.0.inputRegisters.30775_Messwert_Leistung',
                         'modbus.0.inputRegisters.30865_Leistung_Bezug',
                         'modbus.0.inputRegisters.30867_Messwert_Leistung_Einspeisung',
                         'modbus.0.inputRegisters.31393_Batterieladung',
                         'modbus.0.inputRegisters.31395_Batterieentladung'];
            
            if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
                createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
            }
            
            on({id: ids, change: "ne"}, function() {
                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);
            });
            

            Jede Änderung an einem der 5 Werte führt zu einem anderen Ergebnis.
            Also würde ich auf alle 5 triggern.

            @haus-automatisierung @paul53
            Wenn da etwas nicht passen sollte, bitte korrigieren.

            "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

            paul53P 1 Antwort Letzte Antwort
            1
            • CodierknechtC Codierknecht

              Mal eben so hingeschrieben:

              const ids = ['modbus.0.inputRegisters.30775_Messwert_Leistung',
                           'modbus.0.inputRegisters.30865_Leistung_Bezug',
                           'modbus.0.inputRegisters.30867_Messwert_Leistung_Einspeisung',
                           'modbus.0.inputRegisters.31393_Batterieladung',
                           'modbus.0.inputRegisters.31395_Batterieentladung'];
              
              if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
                  createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
              }
              
              on({id: ids, change: "ne"}, function() {
                  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);
              });
              

              Jede Änderung an einem der 5 Werte führt zu einem anderen Ergebnis.
              Also würde ich auf alle 5 triggern.

              @haus-automatisierung @paul53
              Wenn da etwas nicht passen sollte, bitte korrigieren.

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

              @codierknecht sagte: Jede Änderung an einem der 5 Werte führt zu einem anderen Ergebnis.

              Das ist das Problem: Es muss gewartet werden, bis der letzte der zusammen gehörenden Werte aktualisiert wurde.

              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

              CodierknechtC 1 Antwort Letzte Antwort
              0
              • paul53P paul53

                @codierknecht sagte: Jede Änderung an einem der 5 Werte führt zu einem anderen Ergebnis.

                Das ist das Problem: Es muss gewartet werden, bis der letzte der zusammen gehörenden Werte aktualisiert wurde.

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

                @paul53
                Werden die bei Modbus garantiert innerhalb einer bestimmte Zeitspanne alle aktualisiert?
                Wenns mal 600 ms sind, passt der Kram ja auch nicht mehr.

                "Isch aabe gar keine Modbus" :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

                paul53P haus-automatisierungH D 3 Antworten Letzte Antwort
                0
                • CodierknechtC Codierknecht

                  @paul53
                  Werden die bei Modbus garantiert innerhalb einer bestimmte Zeitspanne alle aktualisiert?
                  Wenns mal 600 ms sind, passt der Kram ja auch nicht mehr.

                  "Isch aabe gar keine Modbus" :grin:

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

                  @codierknecht sagte: "Isch aabe gar keine Modbus"

                  Ich auch nicht.

                  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

                  1 Antwort Letzte Antwort
                  0
                  • CodierknechtC Codierknecht

                    @paul53
                    Werden die bei Modbus garantiert innerhalb einer bestimmte Zeitspanne alle aktualisiert?
                    Wenns mal 600 ms sind, passt der Kram ja auch nicht mehr.

                    "Isch aabe gar keine Modbus" :grin:

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

                    @codierknecht sagte in asynch funktion:

                    Werden die bei Modbus garantiert innerhalb einer bestimmte Zeitspanne alle aktualisiert?

                    Normalerweise werden die Register ja der Reihe nach abgefragt. Das heißt, dass das letzte gelesene Register die Logik ausführen sollte. Dann sollten die davor ja alle aktualisiert worden sein.

                    🧑‍🎓 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 sagte in asynch funktion:

                      Werden die bei Modbus garantiert innerhalb einer bestimmte Zeitspanne alle aktualisiert?

                      Normalerweise werden die Register ja der Reihe nach abgefragt. Das heißt, dass das letzte gelesene Register die Logik ausführen sollte. Dann sollten die davor ja alle aktualisiert worden sein.

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

                      @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 ;-)

                      "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

                      D 1 Antwort Letzte Antwort
                      0
                      • CodierknechtC Codierknecht

                        @paul53
                        Werden die bei Modbus garantiert innerhalb einer bestimmte Zeitspanne alle aktualisiert?
                        Wenns mal 600 ms sind, passt der Kram ja auch nicht mehr.

                        "Isch aabe gar keine Modbus" :grin:

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

                        @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 1 Antwort Letzte Antwort
                        0
                        • D Delphinis

                          Hallo,
                          ich möchte in einer Funktion in der ich Werte verrechne, warten, bis alle Werte eingetrudelt sind. Für "wait" muss ich ja offensichtlich eine asynch function verwenden. In den Java Scripts fehlt ja aber der Funktionskopf.
                          Ich habs mal so versucht:

                          async function Eigenverbrauch {
                              // On change
                              on('modbus.0.inputRegisters.30775_Messwert_Leistung', (data) => {
                                  
                                  if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
                                  createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
                                  }
                          
                                  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);
                              });
                          }
                          

                          dies liefert aber den Fehler:

                          15:16:36.440	error	javascript.0 (8848) script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch compile failed: at script.js.Eigene_Scripte.Solar_Leistung_Eigenverbrauch:1
                          

                          Wie kann man das realisieren?

                          Btw: gibt es da irgendwo genauere Fehlermeldungen beim compilieren?

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

                          @delphinis

                          Wenns unbedingt Async sein soll müsste es so gehen (ohne Garantie)

                          Beim ersten Durchlauf passiert jedoch nichts, weil erst der Datenpunkt erstellt wird.

                          on({id:'modbus.0.inputRegisters.30775_Messwert_Leistung', change: "any"}, function (dp) {
                              Eigenverbrauch();
                          });
                          
                          async function Eigenverbrauch () {
                              try {
                          
                                  if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
                                  createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
                                  } else {
                           
                                      const WR = await getStateAsync('modbus.0.inputRegisters.30775_Messwert_Leistung');
                                      const Bezug = await getStateAsync('modbus.0.inputRegisters.30865_Leistung_Bezug');
                                      const Einspeisung = await getStateAsync('modbus.0.inputRegisters.30867_Messwert_Leistung_Einspeisung');
                                      const BatLad = await getStateAsync('modbus.0.inputRegisters.31393_Batterieladung');
                                      const BatEntl = await getStateAsync ('modbus.0.inputRegisters.31395_Batterieentladung');
                          
                                      let eigenverbrauch = (WR.val + Bezug.val - Einspeisung.val -BatLad.val + BatEntl.val);            
                                      await setStateAsync('0_userdata.0.Solar.Leistung.Eigenverbrauch', eigenverbrauch);
                          
                                  }    
                              } catch (error) {
                              log(`Unexpected error - ${error}`, 'error');
                              }
                          }
                          

                          Ich beantworte keine Fragen zu Themen via PN

                          haus-automatisierungH 1 Antwort Letzte Antwort
                          0
                          • PeoplesP Peoples

                            @delphinis

                            Wenns unbedingt Async sein soll müsste es so gehen (ohne Garantie)

                            Beim ersten Durchlauf passiert jedoch nichts, weil erst der Datenpunkt erstellt wird.

                            on({id:'modbus.0.inputRegisters.30775_Messwert_Leistung', change: "any"}, function (dp) {
                                Eigenverbrauch();
                            });
                            
                            async function Eigenverbrauch () {
                                try {
                            
                                    if (!existsState('0_userdata.0.Solar.Leistung.Eigenverbrauch')) {
                                    createState('0_userdata.0.Solar.Leistung.Eigenverbrauch', {type: 'number', read: true, write: true});
                                    } else {
                             
                                        const WR = await getStateAsync('modbus.0.inputRegisters.30775_Messwert_Leistung');
                                        const Bezug = await getStateAsync('modbus.0.inputRegisters.30865_Leistung_Bezug');
                                        const Einspeisung = await getStateAsync('modbus.0.inputRegisters.30867_Messwert_Leistung_Einspeisung');
                                        const BatLad = await getStateAsync('modbus.0.inputRegisters.31393_Batterieladung');
                                        const BatEntl = await getStateAsync ('modbus.0.inputRegisters.31395_Batterieentladung');
                            
                                        let eigenverbrauch = (WR.val + Bezug.val - Einspeisung.val -BatLad.val + BatEntl.val);            
                                        await setStateAsync('0_userdata.0.Solar.Leistung.Eigenverbrauch', eigenverbrauch);
                            
                                    }    
                                } catch (error) {
                                log(`Unexpected error - ${error}`, 'error');
                                }
                            }
                            
                            haus-automatisierungH Online
                            haus-automatisierungH Online
                            haus-automatisierung
                            Developer Most Active
                            schrieb am zuletzt editiert von
                            #14

                            @peoples Na wozu dann noch die anonyme Funktion?

                            Statt

                            on({id:'modbus.0.inputRegisters.30775_Messwert_Leistung', change: "any"}, function (dp) {
                                Eigenverbrauch();
                            });
                             
                            async function Eigenverbrauch () {
                            

                            kannst dann auch gleich

                            on({id:'modbus.0.inputRegisters.30775_Messwert_Leistung', change: "any"}, Eigenverbrauch);
                             
                            async function Eigenverbrauch () {
                            

                            schreiben. Aber wäre dann wieder fast 1:1 identisch zu meiner Version oben - nur dass die Funktion halt nicht anonym ist...

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

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

                              @peoples Na wozu dann noch die anonyme Funktion?

                              Statt

                              on({id:'modbus.0.inputRegisters.30775_Messwert_Leistung', change: "any"}, function (dp) {
                                  Eigenverbrauch();
                              });
                               
                              async function Eigenverbrauch () {
                              

                              kannst dann auch gleich

                              on({id:'modbus.0.inputRegisters.30775_Messwert_Leistung', change: "any"}, Eigenverbrauch);
                               
                              async function Eigenverbrauch () {
                              

                              schreiben. Aber wäre dann wieder fast 1:1 identisch zu meiner Version oben - nur dass die Funktion halt nicht anonym ist...

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

                              @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?

                              Ich beantworte keine Fragen zu Themen via PN

                              paul53P 1 Antwort Letzte Antwort
                              0
                              • 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
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          742

                                          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