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

  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Gelöst: Fehler im Script

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.2k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.9k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.3k

Gelöst: Fehler im Script

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
9 Beiträge 4 Kommentatoren 493 Aufrufe
  • Ä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.
  • M Offline
    M Offline
    michihorn
    schrieb am zuletzt editiert von
    #1

    Hallo

    ich übe gerade das Scripten, kann jemand mal über mein Script schauen, offenbar scheint etwas mit den Scheduler nicht zu klappen, irgend etwas mit den Klammern passt offenbar nicht. Der fehler wird direkt in Zeile1 angezeigt und in der letzten Zeile das gelbe Dreieck.

    Gruß Michael

    schedule("*/2 * * * *", function () {
    createState('Rolladen.WZ_Links');
    createState('Rolladen.WZ_Rechts');
    createState('Rolladen.EZ');
    createState('Rolladen.Küche');
    createState('Rolladen.WC');
    createState('Rolladen.Move_WZ_Links');
    createState('Rolladen.Move_WZ_Rechts');
    createState('Rolladen.Move_EZ');
    createState('Rolladen.Move_Küche');
    createState('Rolladen.Move_WC');
    var Statuswert;
    
    on({id: 'hm-rpc.1.CUX4000002.6.RCVS', change: "ne"}, 
    function (Rolladen) {
    var RL = getState('hm-rpc.1.CUX4000002.6.RCVS').val;
    var Kanal = RL.substr(8, 2);
    var Status = RL.substr(10, 2);
    
    if (Status == "00") {
    Statuswert = "No Information";
    }
    if (Status == "01") {
    Statuswert = "OBEN";
    }
    if (Status == "02") {
    Statuswert = "UNTEN";
    }
    if (Status == "03") {
    Statuswert = "Intermediate position stop";
    }
    if (Status == "04") {
    Statuswert = "Tilt/ventilation position stop";
    }
    if (Status == "05") {
    Statuswert = "Blocking";
    }
    if (Status == "06") {
    Statuswert = "Overheated";
    }
    if (Status == "07") {
    Statuswert = "Timeout";
    }
    if (Status == "08") {
    Statuswert = "Start to move up";
    }
    if (Status == "09") {
    Statuswert = "Start to move down";
    }
    if (Status == "0A") {
    Statuswert = "Fährt AUF";
    }
    if (Status == "0B") {
    Statuswert = "Fährt AB";
    }
    if (Status == "0D") {
    Statuswert = "Stopped in undefined position";
    }
    if (Status == "0E") {
    Statuswert = "Top position stop which is tilt position";
    }
    if (Status == "0F") {
    Statuswert = "Bottom position stop which is intermediate position";
    }
    if (Status == "10") {
    Statuswert = "Switching devices switched off";
    }
    if (Status == "11") {
    Statuswert = "Switching devices switched on";
    }
    if(Kanal == 01) {
    setState('javascript.0.Rolladen.WZ_Links', Statuswert);
    setState('javascript.0.Rolladen.Move_WZ_Links', Status);
    log(Kanal + " WZ Links " + Status + " " + Statuswert);
    }
    else {
    if(Kanal == 02) {
    setState('javascript.0.Rolladen.WZ_Rechts', Statuswert);
    setState('javascript.0.Rolladen.Move_WZ_Rechts', Status);
    log(Kanal + " WZ Rechts " + Status + " " + Statuswert);
    }
    else {
    if(Kanal == 04) {
    setState('javascript.0.Rolladen.EZ', Statuswert);
    setState('javascript.0.Rolladen.Move_EZ', Status);
    log(Kanal + " EZ " + Status + " " + Statuswert);
    }
    else {
    if(Kanal == 08) {
    setState('javascript.0.Rolladen.Küche', Statuswert);
    setState('javascript.0.Rolladen.Move_Küche', Status);
    log(Kanal + " Küche " + Status + " " + Statuswert);
    }
    else {
    if(Kanal == 10) {
    setState('javascript.0.Rolladen.WC', Statuswert);
    setState('javascript.0.Rolladen.Move_WC', Status);
    log(Kanal + " WC " + Status + " " + Statuswert);
    }
    }
    }
    }
    }
    });
    
    1 Antwort Letzte Antwort
    0
    • apollon77A Offline
      apollon77A Offline
      apollon77
      schrieb am zuletzt editiert von
      #2

      Verrätst du uns auch noch welcher Fehler angezeigt wird? Was steht da wenn du über den Fehler bzw das Dreieck mit der Maus gehst?

      Gesendet vom Handy …

      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
      1 Antwort Letzte Antwort
      0
      • M Offline
        M Offline
        michihorn
        schrieb am zuletzt editiert von
        #3

        Hallöchen Apollon77

        in Zeile1 wird Unmatch '{' gezeigt

        und in der letzten Zeile das Warndreieck mit : unrecoverable syntax error (100% scanned)

        wenn ich den scheduler auskommentiere, habe ich keinen Fehler

        Gruß

        Michael

        1 Antwort Letzte Antwort
        0
        • F Offline
          F Offline
          Fitti
          schrieb am zuletzt editiert von
          #4

          Es fehlen zwei Klammern zu ganz am Ende:

          schedule("*/2 * * * *", function () {
          createState('Rolladen.WZ_Links');
          createState('Rolladen.WZ_Rechts');
          createState('Rolladen.EZ');
          createState('Rolladen.Küche');
          createState('Rolladen.WC');
          createState('Rolladen.Move_WZ_Links');
          createState('Rolladen.Move_WZ_Rechts');
          createState('Rolladen.Move_EZ');
          createState('Rolladen.Move_Küche');
          createState('Rolladen.Move_WC');
          var Statuswert;
          }); //schedule Schleife ENDE 
          
          

          So long,

          Fitti

          "Es wird die Zeit kommen, da ihr euch entscheiden müsst zwischen dem, was richtig ist, und dem, was bequem ist."
          Plural von Status ist auch Status!

          1 Antwort Letzte Antwort
          0
          • M Offline
            M Offline
            michihorn
            schrieb am zuletzt editiert von
            #5

            @Fitti:

            Es fehlen zwei Klammern zu ganz am Ende:

            schedule("*/2 * * * *", function () {
            createState('Rolladen.WZ_Links');
            createState('Rolladen.WZ_Rechts');
            createState('Rolladen.EZ');
            createState('Rolladen.Küche');
            createState('Rolladen.WC');
            createState('Rolladen.Move_WZ_Links');
            createState('Rolladen.Move_WZ_Rechts');
            createState('Rolladen.Move_EZ');
            createState('Rolladen.Move_Küche');
            createState('Rolladen.Move_WC');
            var Statuswert;
            }); //schedule Schleife ENDE 
            
            

            So long,

            Fitti `

            Hallo

            wenn ich das richtig verstehe, wird der Code unterhalb der Schedule nach deinem Hinweis gar nicht mehr im Takt der Schedule durchlaufen, oder?

            Ziel soll ja sein, dass das Script gemäß dem Scheduler regelmäßig durchlaufen wird.

            Ich hab die Klammern mal gesetzt und bekomme wieder das Warndreieck.
            326_unbenannt.jpg
            Gruß Michael

            1 Antwort Letzte Antwort
            0
            • apollon77A Offline
              apollon77A Offline
              apollon77
              schrieb am zuletzt editiert von
              #6

              Mit gescheiten Code Einrückungen in jedem Block wäre das viel besser lesbar und sichtbarer.

              Gesendet vom Handy …

              Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

              • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
              • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
              1 Antwort Letzte Antwort
              0
              • M Offline
                M Offline
                michihorn
                schrieb am zuletzt editiert von
                #7

                @apollon77:

                Mit gescheiten Code Einrückungen in jedem Block wäre das viel besser lesbar und sichtbarer.

                Gesendet vom Handy … `

                schedule("*/1 * * * *", function () {
                createState('Rolladen.WZ_Links');
                createState('Rolladen.WZ_Rechts');
                createState('Rolladen.EZ');
                createState('Rolladen.Küche');
                createState('Rolladen.WC');
                createState('Rolladen.Move_WZ_Links');
                createState('Rolladen.Move_WZ_Rechts');
                createState('Rolladen.Move_EZ');
                createState('Rolladen.Move_Küche');
                createState('Rolladen.Move_WC');
                var Statuswert;
                
                on({
                        id: 'hm-rpc.1.CUX4000002.6.RCVS',
                        change: "ne"
                    },
                    function(Rolladen) {
                        var RL = getState('hm-rpc.1.CUX4000002.6.RCVS').val;
                        var Kanal = RL.substr(8, 2);
                        var Status = RL.substr(10, 2);
                
                        if (Status == "00") {
                            Statuswert = "No Information";
                        }
                        if (Status == "01") {
                            Statuswert = "OBEN";
                        }
                        if (Status == "02") {
                            Statuswert = "UNTEN";
                        }
                        if (Status == "03") {
                            Statuswert = "Intermediate position stop";
                        }
                        if (Status == "04") {
                            Statuswert = "Tilt/ventilation position stop";
                        }
                        if (Status == "05") {
                            Statuswert = "Blocking";
                        }
                        if (Status == "06") {
                            Statuswert = "Overheated";
                        }
                        if (Status == "07") {
                            Statuswert = "Timeout";
                        }
                        if (Status == "08") {
                            Statuswert = "Start to move up";
                        }
                        if (Status == "09") {
                            Statuswert = "Start to move down";
                        }
                        if (Status == "0A") {
                            Statuswert = "Fährt AUF";
                            test = '10';
                            log(Value);
                        }
                        if (Status == "0B") {
                            Statuswert = "Fährt AB";
                            test = '11';
                        }
                        if (Status == "0D") {
                            Statuswert = "Stopped in undefined position";
                        }
                        if (Status == "0E") {
                            Statuswert = "Top position stop which is tilt position";
                        }
                        if (Status == "0F") {
                            Statuswert = "Bottom position stop which is intermediate position";
                        }
                        if (Status == "10") {
                            Statuswert = "Switching devices switched off";
                        }
                        if (Status == "11") {
                            Statuswert = "Switching devices switched on";
                        }
                        if (Kanal == 01) {
                            setState('javascript.0.Rolladen.WZ_Links', Statuswert);
                            setState('javascript.0.Rolladen.Move_WZ_Links', Status);
                            log(Kanal + " WZ Links " + Status + " " + Statuswert);
                        } else {
                            if (Kanal == 02) {
                                setState('javascript.0.Rolladen.WZ_Rechts', Statuswert);
                                setState('javascript.0.Rolladen.Move_WZ_Rechts', Status);
                                log(Kanal + " WZ Rechts " + Status + " " + Statuswert);
                            } else {
                                if (Kanal == 04) {
                                    setState('javascript.0.Rolladen.EZ', Statuswert);
                                    setState('javascript.0.Rolladen.Move_EZ', Status);
                                    log(Kanal + " EZ " + Status + " " + Statuswert);
                                } else {
                                    if (Kanal == 08) {
                                        setState('javascript.0.Rolladen.Küche', Statuswert);
                                        setState('javascript.0.Rolladen.Move_Küche', Status);
                                        log(Kanal + " Küche " + Status + " " + Statuswert);
                                    } else {
                                        if (Kanal == 10) {
                                            setState('javascript.0.Rolladen.WC', Statuswert);
                                            setState('javascript.0.Rolladen.Move_WC', Status);
                                            log(Kanal + " WC " + Status + " " + Statuswert);
                                        }
                                    }
                                }
                            }
                        }
                    });
                

                So in etwa?

                Michael

                1 Antwort Letzte Antwort
                0
                • paul53P Offline
                  paul53P Offline
                  paul53
                  schrieb am zuletzt editiert von
                  #8

                  Es fehlt der Abschluss von Schedule.

                          }
                      }); // on
                  }); // schedule
                  

                  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
                  • M Offline
                    M Offline
                    michihorn
                    schrieb am zuletzt editiert von
                    #9

                    @paul53:

                    Es fehlt der Abschluss von Schedule.

                            }
                        }); // on
                    }); // schedule
                    ```` `  
                    

                    Dankeschön ;-)

                    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

                    600

                    Online

                    32.4k

                    Benutzer

                    81.4k

                    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