Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. Ausführen von aktualisierendem JavaScript Code

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Ausführen von aktualisierendem JavaScript Code

    This topic has been deleted. Only users with topic management privileges can see it.
    • _
      _techniker_ @DeeJayDave last edited by _techniker_

      @deejaydave said in Ausführen von aktualisierendem JavaScript Code:

      @eierfeile Hallo zusammen,
      vielen Dank für das Skript! 🙂 Tolle Arbeit. Ich habe jedoch noch Einträge im Log, die ich nicht fixen kann:

      javascript.0
      2021-09-02 10:37:40.159	warn	You are assigning a string to the state "alias.0.Youless_Zählerstand" which expects a number. Please fix your code to use a number or change the state type to string. This warning might become an error in future versions.
      
      javascript.0
      2021-09-02 10:37:40.088	info	State value to set for "0_userdata.0.Youless_Gesamtverbrauch" has to be type "number" but received type "string"
      

      Könnt ihr mir verraten, wie euer Datenpunkt "Gesamtverbrauch" definiert ist?

      Das würde mich auch interessieren.

      23457,066 ist mein Wert und bekomme die selber Meldung.

      ...
      createState('Aktuelle_Leistung', {type: 'number', unit: 'W', role: 'value.power'});
      createState('Zählerstand', {type: 'number' , unit: 'kWh', role: 'value.power'});
      ...
      setState('Zählerstand', obj.cnt, true);
               setState('Aktuelle_Leistung', obj.pwr, true);
      

      Aktuelle_Leistung wird ohne Fehler übernohmen.

      1 Reply Last reply Reply Quote 0
      • D
        DeeJayDave last edited by

        Keiner ne Idee dazu? 😞

        _ 1 Reply Last reply Reply Quote 0
        • _
          _techniker_ @DeeJayDave last edited by

          @deejaydave said in Ausführen von aktualisierendem JavaScript Code:

          Keiner ne Idee dazu? 😞

          Sieht so aus. Schade. 😞

          _ 1 Reply Last reply Reply Quote 0
          • _
            _techniker_ @_techniker_ last edited by _techniker_

            @_techniker_

            http://192.168.*.*/a?f=j
            

            Mit diesem Befehl lese ich die Daten aus und bekomme:

            cnt " 23559,653"
            pwr 661
            lvl 24
            dev "(±0%)"
            det ""
            con ""
            sts ""
            cs0 " 0,000"
            ps0 0
            raw 221

            Evtl liegt es ja an " "
            Nur wie bekomme ich das weg?

            1 Reply Last reply Reply Quote 0
            • D
              DeeJayDave last edited by

              So wie es aussieht, werden wir mit diesem Fehler leben müssen 😞

              Asgothian 1 Reply Last reply Reply Quote 0
              • Asgothian
                Asgothian Developer @DeeJayDave last edited by

                @deejaydave sagte in Ausführen von aktualisierendem JavaScript Code:

                So wie es aussieht, werden wir mit diesem Fehler leben müssen 😞

                Nein, müsst ihr nicht. Die Lösung ist aber extrem einfach:

                An Stelle von

                setState('Zählerstand', obj.cnt, true);
                setState('Aktuelle_Leistung', obj.pwr, true);
                
                setState('Zählerstand',parseFloat( obj.cnt), true);
                setState('Aktuelle_Leistung', parseFloat(obj.pwr), true);
                
                _ 1 Reply Last reply Reply Quote 0
                • D
                  DeeJayDave last edited by

                  @asgothian Danke dir für die Rückmeldung. Ich hab das Blockly-Skript von "eierfeile" nachgebaut und so sieht mein javaskript aus:

                  var result;

                  schedule("*/5 * * * * *", async function () {
                    try {
                      require("request")('http://192.168.178.73/a?f=j', async function (error, response, result) {
                        setState("0_userdata.0.Youless_Gesamtverbrauch"/*Youless_Gesamtverbrauch*/, getAttr((function () { try {return JSON.parse(result);} catch(e) {return {};}})(), 'cnt'));
                      setState("0_userdata.0.Youless_Momentanverbrauch"/*Youless_Momentanverbrauch*/, getAttr((function () { try {return JSON.parse(result);} catch(e) {return {};}})(), 'pwr'));
                      setState("0_userdata.0.Youless_Signalstaerke"/*Youless_Signalstaerke*/, getAttr((function () { try {return JSON.parse(result);} catch(e) {return {};}})(), 'lvl'));
                      }).on("error", function (e) {console.error(e);});
                    } catch (e) { console.error(e); }
                  });
                  

                  Könntest du mir verraten wo und wie ich das in dieses Skript einbauen soll? Danke im Voraus 🙂

                  Asgothian 1 Reply Last reply Reply Quote 0
                  • Asgothian
                    Asgothian Developer @DeeJayDave last edited by

                    @deejaydave

                    Das parsefloat muss um die getattr Aufrufe herum gesetzt werden.

                    A.

                    D 1 Reply Last reply Reply Quote 0
                    • D
                      DeeJayDave @Asgothian last edited by

                      @asgothian Verstehe, danke. Aber in meinem Fall (ich nutze Blockly) kann ich es gar nicht einfügen. Also müsste ich das Blockly-Skript löschen und stattdessen ein Javaskript aufsetzen? Oder gibt es eine Möglichkeit den parsefloat im Blockly einzusetzen?

                      Asgothian 1 Reply Last reply Reply Quote 0
                      • Asgothian
                        Asgothian Developer @DeeJayDave last edited by

                        @deejaydave Es gibt einen Konvertierungsbaustein (bei mir im englischen toNumber) den du da vor einhängen kannst.

                        A.

                        D 1 Reply Last reply Reply Quote 1
                        • D
                          DeeJayDave @Asgothian last edited by

                          @asgothian Manchmal sieht man den Wald vor lauter Bäumen nicht. Danke!

                          1 Reply Last reply Reply Quote 0
                          • _
                            _techniker_ @Asgothian last edited by

                            @asgothian said in Ausführen von aktualisierendem JavaScript Code:

                            @deejaydave sagte in Ausführen von aktualisierendem JavaScript Code:

                            So wie es aussieht, werden wir mit diesem Fehler leben müssen 😞

                            Nein, müsst ihr nicht. Die Lösung ist aber extrem einfach:

                            An Stelle von

                            setState('Zählerstand', obj.cnt, true);
                            setState('Aktuelle_Leistung', obj.pwr, true);
                            
                            setState('Zählerstand',parseFloat( obj.cnt), true);
                            setState('Aktuelle_Leistung', parseFloat(obj.pwr), true);
                            

                            Bekomme ich weiterhin die Fehlermeldung von influxdb.

                            Do not store value " 23457,173" for javascript.0.Zählerstand because no number

                            1 Reply Last reply Reply Quote 0
                            • B
                              Bruchpilot87 last edited by Bruchpilot87

                              Guten Abend in die Runde,

                              ich visualisiere die Werte aus der influxdb in Grafana. Leider habe ich Probleme den Gesamtverbrauch in Grafana zu visualisieren. Im IOBroker Adapter sehe ich den aktuellen Wert als Objekt. Nur kann ich in Grafana diesen Wert nicht einlesen. Folgenden Fehler erhalte ich in Grafana -> InfluxDB Error: unsupported mean iterator type: *query.stringInterruptIterator

                              Jemand eine Idee?

                              Gruß
                              Christian

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

                              Support us

                              ioBroker
                              Community Adapters
                              Donate

                              405
                              Online

                              31.8k
                              Users

                              79.9k
                              Topics

                              1.3m
                              Posts

                              14
                              32
                              5349
                              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