Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Nudging - Nur einen Wert in eine Variable für Sayit

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Nudging - Nur einen Wert in eine Variable für Sayit

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

      @skorpil:

      Und das ist das Log:

      Zitat:

      javascript-0 2015-11-05 12:56:31 info script.js.Test_Sayit_mit_Variable: registered 1 subscription and 0 schedules

      javascript-0 2015-11-05 12:56:31 info Start javascript script.js.Test_Sayit_mit_Variable

      javascript-0 2015-11-05 12:56:31 info Stop script script.js.Test_Sayit_mit_Variable `
      Das ist noch nicht sehr aufschlussreich, da fehlt noch was. Kannst du die Zeile im Code mal ändern, damit man sie im Log leichter findet?

      aus

      log((typeof data.newState.val) + ' ' + data.newState.val);
      

      wird

      log('Die Variable hm-rega.0.38101.STATE hat den Typ ' + (typeof data.newState.val) + ' und den Wert ' + data.newState.val);
      

      Dann bitte das Skript neu starten und gucken, was da im Log steht. Danke.

      Pix

      1 Reply Last reply Reply Quote 0
      • S
        skorpil last edited by

        Das mache ich! Muss jetzt leider arbeiten und melde mich am Abend. Danke!

        1 Reply Last reply Reply Quote 0
        • S
          skorpil last edited by

          So, jetzt habe ich das Script geändert. Mit diesem Script

          var status_Sayit = ['ein','aus'];
          on("hm-rega.0.38101.STATE"/*Variable*/, function (data) {
              log('Die Variable hm-rega.0.38101.STATE hat den Typ ' + (typeof data.newState.val) + ' und den Wert ' + data.newState.val);
              var status_geraet = 'Variable Sayit',         // Klartextname des Gerätes // alternativ: status_geraet = data.name;
                    status_variable = 0;
              if (data.newState.val === true) {
                  status_variable = 1;
               } else {
                  status_variable = 0;
               }
              var ansage = status_geraet + ' ' + status_Sayit[status_variable];
              log(ansage, 'info');
              setState("sayit.0.tts.text"/*Text to speech*/, ansage);
          });
          

          kommt dieses Ergebnis im Log:

          ` > javascript-0 2015-11-06 09:19:01 info script.js.Test_Sayit_mit_Variable: registered 1 subscription and 0 schedules

          javascript-0 2015-11-06 09:19:01 info Start javascript script.js.Test_Sayit_mit_Variable `

          Was bedeutet das?

          Ich habe auch den Wert der Variable von AUS auf EIN und umgekehrt geschaltet. Ein weiterer Log Eintrag kommt nicht

          1 Reply Last reply Reply Quote 0
          • P
            pix last edited by

            Hallo skorpil,

            ich glaube, das ist nicht das vollständige Log. Das Skript fragt nach Änderungen des Homematic Rega Datenpunktes 38101. Wenn dieser sich ändert wird ein Log mit dem Text "Die variable hm-rega.0.38101.STATE hat den Typ ******" geschrieben (Zeile 3 der Funktion). Diese Zeile aus dem Log würde ich gern sehen. Vielleicht ändert sich ja dieser Rega-Datenpunkt nicht und die Funktion löst gar nicht aus?

            Gruß

            Pix

            1 Reply Last reply Reply Quote 0
            • S
              skorpil last edited by

              Pix,

              das habe ich auch schon gedacht. Aber in der Homematic habe ich den Datenpunkt schon mehrfach hin- und her geändert. Vielleicht wird diese Änderung aber nicht an der iobroker resp. den Raspi weitergegeben. Mindestens nicht sofort….

              1 Reply Last reply Reply Quote 0
              • S
                skorpil last edited by

                So, ich habe mir das gerade in den EREIGNISSEN im iobroker angesehen. Wie im Anhang zu sehen: der Wert der Variable ändert sich! Dennoch löst das Script offenbar NICHT aus. Was ist falsch?

                Gruß

                Bernd

                PS: Danke, PIX, ich bin Dir sehr dankbar für Deine Hilfe
                622_image.jpeg
                622_image.jpeg

                1 Reply Last reply Reply Quote 0
                • P
                  pix last edited by

                  Hallo Bernd,

                  ich bin da jetzt auch überfragt. Ich habe das Skript mal bei laufen lassen (natürlich mit einem eigenen Datenpunkt). Klappt einwandfrei.

                  ! 2015-11-06 18:03:55.177 - info: javascript.0 Start javascript script.js.AaaTEST 2015-11-06 18:03:55.199 - info: javascript.0 script.js.AaaTEST: registered 1 subscription and 0 schedules 2015-11-06 18:03:59.606 - info: javascript.0 script.js.Status_Geraete: Status Heizung auf DIY Fernbedienung eingeschaltet 2015-11-06 18:03:59.606 - info: javascript.0 script.js.AaaTEST: Die Variable hm-rega.0.38101.STATE hat den Typ boolean und den Wert true 2015-11-06 18:03:59.607 - info: javascript.0 script.js.AaaTEST: Variable Sayit aus 2015-11-06 18:03:59.617 - info: sayit.0 saying: /Users/pix/Documents/iobroker/node_modules/iobroker.sayit/gong.mp3 2015-11-06 18:04:00.627 - info: sayit.0 saying: Variable Sayit aus 2015-11-06 18:04:01.093 - info: sayit.0 Copied file '/Users/pix/Documents/iobroker/node_modules/iobroker.sayit/say.mp3' to '/Users/pix/Documents/iobroker/cache/4e1a347e8e7888e94f61428cf7271091.mp3' 2015-11-06 18:04:23.102 - info: javascript.0 script.js.Status_Geraete: Status Heizung auf DIY Fernbedienung ausgeschaltet 2015-11-06 18:04:23.102 - info: javascript.0 script.js.AaaTEST: Die Variable hm-rega.0.38101.STATE hat den Typ boolean und den Wert false 2015-11-06 18:04:23.103 - info: javascript.0 script.js.AaaTEST: Variable Sayit ein 2015-11-06 18:04:23.114 - info: sayit.0 saying: /Users/pix/Documents/iobroker/node_modules/iobroker.sayit/gong.mp3 2015-11-06 18:04:24.115 - info: sayit.0 saying: Variable Sayit ein 2015-11-06 18:04:24.299 - info: sayit.0 Copied file '/Users/pix/Documents/iobroker/node_modules/iobroker.sayit/say.mp3' to '/Users/pix/Documents/iobroker/cache/e7bd9825975db829fb2ae069edbcd4ad.mp3' !

                  Da weiß ich leider auch nicht weiter. 😞 Das Skript ist nicht der Fehler.

                  Gruß,

                  Pix

                  1 Reply Last reply Reply Quote 0
                  • S
                    skorpil last edited by

                    PIX,

                    ich habs! Der Fehler war hier:

                    on("hm-rega.0.38101.STATE"/*Variable*/, function (data)
                    

                    Der Ausdruck "Variable" war falsch. Es muß richtig heißen

                     on("hm-rega.0.38101"/*Test_Sayit*/, function (data)
                    

                    Denn mein Script heißt "Test_Sayit". Ich hatte geglaubt, diese Angaben im Code in den Sternchen sind Kommentare. Als ich ochmal im Script gespielt habe, bin ich zufällig mal auf den Button oben rechts "ID" einfügen gegangen und so ist mir das aufgefallen.

                    Ich danke dem Forum und vor allem Dir, PIX, für die Unterstützung. Ich habe was gelernt.

                    1 Reply Last reply Reply Quote 0
                    • P
                      pix last edited by

                      Hallo Bernd,

                      freut mich, wenn es jetzt klappt. ABER:
                      @skorpil:

                      Der Ausdruck "Variable" war falsch. Es muß richtig heißen ` /* Kommentar ein

                      */ Kommentar aus

                      Was dazwischen steht ist Kommentar und spielt somit keine Rolle.

                      Das ist aber noch ein anderer Unterschied in deinen zwei Codes
                      @skorpil:

                      on("hm-rega.0.38101.STATE"/*Variable*/, function (data)
                      

                      on("hm-rega.0.38101"/*Test_Sayit*/, function (data) ` Der zweite Code geht nicht auf den Datenpunkt STATE. Muss vielleicht nicht so sein bei Rega, kann ich aber nicht genau sagen.

                      Kann jemand helfen?

                      Pix

                      1 Reply Last reply Reply Quote 0
                      • S
                        skorpil last edited by

                        Pix,

                        Danke für den Hinweis. Dann war meine Vermutung hinsichtlich der Kommentare doch richtig.

                        Das mit "State" hatte ich gar nicht gesehen. Ich teste das morgen mal mit und ohne und

                        berichte dann!

                        Liebe Grüße

                        Bernd

                        1 Reply Last reply Reply Quote 0
                        • S
                          skorpil last edited by

                          So, mit "STATE" getestet! Ergebnis:

                          mit "STATE2 funktioniert es nicht, ohne "STATE2 funktioniert es.

                          Was sagt uns das?

                          1 Reply Last reply Reply Quote 0
                          • S
                            skorpil last edited by

                            Ich bin auf eine interessantes Phänomen bei sayit gestoßen. Augenscheinlich ist es so, daß die Sonos Ansage nicht mehr korrekt codiert wird, wenn der anzusagende Text eine bestimmte Länge überschreitet. In folgendem Beispiel

                            // Einfache Temperaturansage mit SayIt.
                            // Variante 2 mittels ersetzen des Punktes in ein Komma, damit die Ausgabe nicht
                            // "Es sind 18 Punkt 2 Grad " sagt.
                            
                            var idSayIt = "sayit.0.tts.text";  /*Text to speech*/
                            var Temperatursensor = getState("hm-rpc.0.XXXXXXXXX.1.TEMPERATURE"); /*Temperatursensor:1.TEMPERATURE*/
                            var temperatur = Temperatursensor.val.toString();
                            var bla = "bla bla bla bla bla bla bla bla bla"
                            temperatur = temperatur.replace('\.', '\,');
                            
                            setState (idSayIt, "Die Temperatur beträgt " + temperatur + " Grad." + bla );
                            

                            ist die Länge der "bla bla" irgendwie begrenzt. So ca. bei insgesamt 60 - 70 Buchstaben (inkl. der Temperatur Ansage) ist Schluß. Bis dahin wird der Text korrekt angesagt. Danach bekomme ich bei Sonos die Fehlermeldung, das mp3 sei nicht richtig codiert.

                            Was tun? Denn ich wollte eigentlich in einem Script ansagen "Guten Morgen. Heute ist x-tag, der XX.XX.XX, es ist xx:xx Uhr und ei Aussentemperatur beträgt x,x Grad" Das ist aber scheinbar zu viel Text. Irgendwo ist da ein Bug oder eine Begrenzung.

                            1 Reply Last reply Reply Quote 0
                            • P
                              pix last edited by

                              Zu Länge der Ansage hat Bluefox mal hier was geschrieben:

                              http://forum.iobroker.net/viewtopic.php … 496#p12862

                              Gruß,

                              Pix

                              1 Reply Last reply Reply Quote 0
                              • S
                                skorpil last edited by

                                Hallo Pix,

                                Das löst zwar das Problem nicht. Aber es erklärt es. Schade dass es zu dem Adapter keine weiteren Infos gibt.

                                1 Reply Last reply Reply Quote 0
                                • S
                                  skorpil last edited by

                                  @Fitti:

                                  Danke.

                                  Das mit der 0 habe ich jetzt abgefangen.

                                  // Einfache Temperaturansage mit SayIt.
                                  // Variante 1 mittels splitten der Temperatur, damit die Ansage nicht
                                  // "Es sind 18 Punkt 2 Grad " sagt.
                                  
                                  var idSayIt = "sayit.0.tts.text";  /*Text to speech*/
                                  var Temperatursensor = getState("hm-rpc.0.LEQ00xxxxx.1.TEMPERATURE"); /*Temperatursensor:1.TEMPERATURE*/
                                  var temperatur = Temperatursensor.val.toString();
                                  var temp_array = [];
                                  
                                  temp_array = temperatur.split(".");
                                  
                                  // Fange leere Nachkommastellen ab. Das passiert, wenn die Temperatur z. B. 18.0 ist.
                                  // Es wird dann nur "18" gelesen.
                                  if (!temp_array[1]) {
                                      temp_array[1] = "0";
                                      log("Die Nach-Kommastelle in temp_array[1] war nicht vorhanden und wird nun fest auf 0 gesetzt.");
                                  }
                                  setState (idSayIt, "Die Temperatur beträgt " + temp_array[0] + "," + temp_array[1] + " Grad.");
                                  
                                  
                                  // Einfache Temperaturansage mit SayIt.
                                  // Variante 2 mittels ersetzen des Punktes in ein Komma, damit die Ausgabe nicht
                                  // "Es sind 18 Punkt 2 Grad " sagt.
                                  
                                  var idSayIt = "sayit.0.tts.text";  /*Text to speech*/
                                  var Temperatursensor = getState("hm-rpc.0.LEQ00xxxxx.1.TEMPERATURE"); /*Temperatursensor:1.TEMPERATURE*/
                                  var temperatur = Temperatursensor.val.toString();
                                  
                                  temperatur = temperatur.replace('\.', '\,');
                                  
                                  setState (idSayIt, "Die Temperatur beträgt " + temperatur + " Grad.");
                                  

                                  Vielleicht hat ja jemand auch mal das Problem. `

                                  Brauche da nochmal Hilfe. Ich habe den Code der Variante 1 in ein eigenes Script eingebaut http://forum.iobroker.net/viewtopic.php … 9&start=40

                                  Nur, aus irgendwelchen Gründen aktualisiert iobroker die Temperaturwerte nicht. Irgendwie hat er sich 2.3 Grad vom erstenmal aufrufen gemerkt und Änderungen, wie z.B. derzeit minus 3,5 Grad werden nicht wiedergegeben. Woran könnte das liegen?

                                  1 Reply Last reply Reply Quote 0
                                  • P
                                    pix last edited by

                                    Hallo,

                                    bin dem Link gefolgt und habe den Eintrag mit dem Skript durchgesehen. Da gibt es diese Zeile:

                                    var Temperatursensor = getState("hm-rpc.0.LEQ0177463.1.TEMPERATURE"); /*Temperatursensor:1.TEMPERATURE*/
                                    ````da fehlt ein ".val":
                                    

                                    var Temperatursensor = getState("hm-rpc.0.LEQ0177463.1.TEMPERATURE").val; /Temperatursensor:1.TEMPERATURE/

                                    Gruß
                                    
                                    Pix
                                    1 Reply Last reply Reply Quote 0
                                    • First post
                                      Last post

                                    Support us

                                    ioBroker
                                    Community Adapters
                                    Donate

                                    1.1k
                                    Online

                                    31.7k
                                    Users

                                    79.7k
                                    Topics

                                    1.3m
                                    Posts

                                    8
                                    60
                                    6293
                                    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