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. Object.<anonymous> finden?

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    14
    1
    244

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    1.8k

Object.<anonymous> finden?

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
51 Beiträge 5 Kommentatoren 4.0k Aufrufe 3 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.
  • SMSS SMS

    @haus-automatisierung meinst du das:

    javascript.0	09:00:34.141	info	Stopping script script.js.Küche.Siemens_Spülmaschine
    javascript.0	09:01:09.265	info	Start JavaScript script.js.Küche.Siemens_Spülmaschine (Blockly)
    javascript.0	09:01:09.300	info	script.js.Küche.Siemens_Spülmaschine: registered 13 subscriptions, 2 schedules, 0 messages, 0 logs and 0 file subscriptions
    homeconnect.0	09:10:21.528	silly	States user redis pmessage homeconnect.0.*/homeconnect.0.013060393307000289.programs.active.BSH_Common_Root_ActiveProgram:{"val":"Dishcare.Dishwasher.Program.Eco50","ack":false,"ts":1745392221521,"q":0,"c":"script.js.Küche.Siemens_Spülmaschine","from":"system.adapter.javascript.0","user":"system.user.admin","lc":1745391503639}
    homeconnect.0	09:10:21.531	silly	States user redis pmessage homeconnect.0.*/homeconnect.0.013060393307000289.settings.BSH_Common_Setting_PowerState:{"val":"BSH.Common.EnumType.OperationState.On","ack":false,"ts":1745392221521,"q":0,"c":"script.js.Küche.Siemens_Spülmaschine","from":"system.adapter.javascript.0","user":"system.user.admin","lc":1745392221521}
    javascript.0	09:10:51.521	warn	at Object.<anonymous> (script.js.Küche.Siemens_Spülmaschine:64:3)
    
    CodierknechtC Offline
    CodierknechtC Offline
    Codierknecht
    Developer Most Active
    schrieb am zuletzt editiert von
    #5

    @sms
    Ist es gewollt, dass Du Dir mit der Logstufe silly für den Homeconnect das Log vollballerst?

    Wenn das nur übergangsweise zu Debug-Zwecken so ist, habe ich nix gesagt ;-)

    "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

    SMSS 1 Antwort Letzte Antwort
    0
    • CodierknechtC Codierknecht

      @sms
      Javascript ist untypisiert. Das heißt: Der Typ einer Variablen ergibt sich aus seiner Verwendung.
      Du mixt hier aber Number (Zahlenwerte) mit Boolean (wahr/falsch).
      b01cf3a3-96de-4f3a-b57d-c631a85b75d8-image.png
      Letztlich schreibst Du damit im Fall der Fälle auch den falschen Typ in den Datenpunkt, denn der wird ja auch entweder Boolean oder Number sein.

      Statt "Falsch" sollte bei 'ner 0 also etwas anderes in den DP geschrieben werden. z.B. eine 0 oder -1.
      Das ganze soll wohl dazu dienen, dass die Spülmaschine nicht automatisch (per Timer) gestartet wird, oder?

      Apropos Spülmachine: Früher oder später (meist früher) wird sich die Verwendung von Umlauten (und anderer Sonderzeichen) in Variablen und ID's rächen.

      Außerdem gibt es für die Prüfung auf verschiedene Werte effizientere Möglichkeiten:
      17d4e5ec-5d27-44b0-acb5-d994d573a304-image.png

      SMSS Offline
      SMSS Offline
      SMS
      schrieb am zuletzt editiert von
      #6

      @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.
      d1973a45-4b87-40c3-a5ff-9dade0057612-grafik.png

      Die Spülmaschine soll angehen, je nachdem welchen Wert ich einstelle und meine PV-Produktion diesen Wert überschreitet.
      Das Ganze sieht so aus:
      f5abb26f-80ad-4dc2-9acf-4ffdd54a3535-grafik.png

      0 bedeutet = AUS

      Die Umlaute werde ich nach und nach elemenieren.

      1 Antwort Letzte Antwort
      0
      • CodierknechtC Codierknecht

        @sms
        Ist es gewollt, dass Du Dir mit der Logstufe silly für den Homeconnect das Log vollballerst?

        Wenn das nur übergangsweise zu Debug-Zwecken so ist, habe ich nix gesagt ;-)

        SMSS Offline
        SMSS Offline
        SMS
        schrieb am zuletzt editiert von
        #7

        @codierknecht Da ich davon keine Ahnung habe, ... , nein es ist nicht gewollt. Wo ändere ich das?

        CodierknechtC 1 Antwort Letzte Antwort
        0
        • SMSS SMS

          @codierknecht Da ich davon keine Ahnung habe, ... , nein es ist nicht gewollt. Wo ändere ich das?

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

          @sms sagte in Object.<anonymous> finden?:

          Wo ändere ich das?

          In den Instanzeinstellungen (Expertenmodus)

          fd257b3b-28e6-462c-b7c6-98e96f511415-image.png

          "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

          SMSS 1 Antwort Letzte Antwort
          0
          • CodierknechtC Codierknecht

            @sms sagte in Object.<anonymous> finden?:

            Wo ändere ich das?

            In den Instanzeinstellungen (Expertenmodus)

            fd257b3b-28e6-462c-b7c6-98e96f511415-image.png

            SMSS Offline
            SMSS Offline
            SMS
            schrieb am zuletzt editiert von
            #9

            @codierknecht was bedeutet debug?

            CodierknechtC 1 Antwort Letzte Antwort
            0
            • SMSS SMS

              @codierknecht was bedeutet debug?

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

              @sms sagte in Object.<anonymous> finden?:

              was bedeutet debug?

              Das ist nur ein Beispiel aus meinem Testsystem. Auch damit werden jede Menge Infos ins Log geschrieben, die im stabilen Betrieb nicht wirklich nötig sind.

              Üblich ist die Einstellung "Info". Wäre hier erstmal meine Empfehlung.

              Ich gehe noch einen Schritt weiter und stelle die Adapter, die wirklich stabil ihren Dienst verrichten, aber zu viel Zeug ins Log schreiben, auf "Warning".
              Und wer dann noch zu viel unnützes Zeug plappert, bekommt "Error" und darf damit nur noch bei Fehlern etwas ins Log schreiben. So ist das am Ende des Tages nur noch < 100 kB groß.

              "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

              SMSS 1 Antwort Letzte Antwort
              0
              • CodierknechtC Codierknecht

                @sms sagte in Object.<anonymous> finden?:

                was bedeutet debug?

                Das ist nur ein Beispiel aus meinem Testsystem. Auch damit werden jede Menge Infos ins Log geschrieben, die im stabilen Betrieb nicht wirklich nötig sind.

                Üblich ist die Einstellung "Info". Wäre hier erstmal meine Empfehlung.

                Ich gehe noch einen Schritt weiter und stelle die Adapter, die wirklich stabil ihren Dienst verrichten, aber zu viel Zeug ins Log schreiben, auf "Warning".
                Und wer dann noch zu viel unnützes Zeug plappert, bekommt "Error" und darf damit nur noch bei Fehlern etwas ins Log schreiben. So ist das am Ende des Tages nur noch < 100 kB groß.

                SMSS Offline
                SMSS Offline
                SMS
                schrieb am zuletzt editiert von SMS
                #11

                @codierknecht OK, danke!

                Das eigentliche Problem liegt jetzt aber hier?

                @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.
                d1973a45-4b87-40c3-a5ff-9dade0057612-grafik.png

                Die Spülmaschine soll angehen, je nachdem welchen Wert ich einstelle und meine PV-Produktion diesen Wert überschreitet.
                Das Ganze sieht so aus:
                f5abb26f-80ad-4dc2-9acf-4ffdd54a3535-grafik.png

                0 bedeutet = AUS

                haus-automatisierungH 1 Antwort Letzte Antwort
                0
                • SMSS SMS

                  @codierknecht OK, danke!

                  Das eigentliche Problem liegt jetzt aber hier?

                  @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.
                  d1973a45-4b87-40c3-a5ff-9dade0057612-grafik.png

                  Die Spülmaschine soll angehen, je nachdem welchen Wert ich einstelle und meine PV-Produktion diesen Wert überschreitet.
                  Das Ganze sieht so aus:
                  f5abb26f-80ad-4dc2-9acf-4ffdd54a3535-grafik.png

                  0 bedeutet = AUS

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

                  Kannst Du mal bitte das komplette Script zeigen? Da fehlt ja definitiv noch Code. Im Screenshot erkennt man ja einen weiteren Trigger usw.

                  @sms sagte in Object.<anonymous> finden?:

                  @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.

                  Das kann man schon so machen, aber schön/sauber ist das nicht. Ist zumindest nicht das Problem hier für die Fehlermeldung.

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

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

                    Kannst Du mal bitte das komplette Script zeigen? Da fehlt ja definitiv noch Code. Im Screenshot erkennt man ja einen weiteren Trigger usw.

                    @sms sagte in Object.<anonymous> finden?:

                    @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.

                    Das kann man schon so machen, aber schön/sauber ist das nicht. Ist zumindest nicht das Problem hier für die Fehlermeldung.

                    SMSS Offline
                    SMSS Offline
                    SMS
                    schrieb am zuletzt editiert von
                    #13
                    var Uhrzeit, Auto_Ein_bei, Steckdose_Dauerein, Hand, Wartezeit_Verbindungsaufbau, Wartezeit, Wartezeit3, Wartezeit2;
                    
                    
                    on({ id: [].concat(['homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_StartInRelative']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      setState('0_userdata.0.Küche.Siemens_Spülmaschine_Startzeit_Stunden' /* Siemens Spülmaschine Startzeit Stunden */, (getState('homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_StartInRelative').val / 3600), true);
                      setState('0_userdata.0.Küche.Siemens_Spülmaschine_Startzeit_Minuten' /* Siemens Spülmaschine Startzeit Minuten */, (getState('homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_StartInRelative').val / 60), true);
                    });
                    on({ id: [].concat(['sonoff.0.Spülmaschine.alive']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      if ((obj.state ? obj.state.val : '') == false) {
                        setState('0_userdata.0.Küche.SD_Spülmaschine_am_Leben' /* SD Spülmaschine am Leben */, false, true);
                      } else {
                        setState('0_userdata.0.Küche.SD_Spülmaschine_am_Leben' /* SD Spülmaschine am Leben */, true, true);
                      }
                    });
                    schedule("0,30 * * * *", async () => {
                      setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbrauch' /* Siemens_Spülmaschine_Verbrauch */, (getState('sonoff.0.Spülmaschine.ENERGY_Total').val - 405.155), true);
                    });
                    on({ id: [].concat(['homeconnect.0.013060393307000289.status.BSH_Common_Status_OperationState']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      if ((obj.state ? obj.state.val : '') == 'BSH.Common.EnumType.OperationState.Run') {
                        setState('0_userdata.0.Küche.Spülgänge' /* Spülgänge */, (getState('0_userdata.0.Küche.Spülgänge').val + 1), true);
                      }
                    });
                    on({ id: [].concat(['homeconnect.0.013060393307000289.status.BSH_Common_Status_OperationState']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      if ((obj.state ? obj.state.val : '') == 'BSH.Common.EnumType.OperationState.Ready') {
                        setStateDelayed('0_userdata.0.Küche.Siemens_Spülmaschine_Durchnittskosten' /* Siemens Spülmaschine Durchnittskosten */, (getState('0_userdata.0.Küche.Spülmaschine_Verbrauchskosten').val / getState('0_userdata.0.Küche.Spülgänge').val), true, 60000, false);
                      }
                    });
                    schedule("0,30 * * * *", async () => {
                      setState('0_userdata.0.Küche.Spülmaschine_Verbrauchskosten' /* Spülmaschine Verbrauchskosten */, (getState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbrauch').val * getState('javascript.0.Meine_Datenpunkte.Strom.Kosten.Arbeitspreis_/kWh_Bezug_Energieversorger').val), true);
                    });
                    on({ id: [].concat(['homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_RemainingProgramTime']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      setState('0_userdata.0.Küche.Siemens_Spülmaschine_Restlaufzeit' /* Siemens Spülmaschine Restlaufzeit */, (getState('homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_RemainingProgramTime').val / 60), true);
                    });
                    scheduleById('0_userdata.0.Haushaltsgeraete.01_Uhrzeit_Spuelmaschine' /* 01_Uhrzeit Spuelmaschine */, async () => {
                      if (Uhrzeit) {
                        setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, true);
                      }
                    });
                    on({ id: [].concat(['0_userdata.0.Küche.Siemens_Spülmaschine_Auto_ein_bei']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      if ((obj.state ? obj.state.val : '') == 1) {
                        Auto_Ein_bei = 1500;
                      } else if ((obj.state ? obj.state.val : '') == 2) {
                        Auto_Ein_bei = 2000;
                      } else if ((obj.state ? obj.state.val : '') == 3) {
                        Auto_Ein_bei = 3000;
                      } else if ((obj.state ? obj.state.val : '') == 4) {
                        Auto_Ein_bei = 4000;
                      } else if ((obj.state ? obj.state.val : '') == 0) {
                        Auto_Ein_bei = false;
                      }
                      setState('0_userdata.0.Küche.Auto_ein_bei' /* Auto ein bei */, Auto_Ein_bei, true);
                    });
                    on({ id: [].concat(['0_userdata.0.Küche.Spülmaschine_Ein/Aus']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      Uhrzeit = false;
                      setState('0_userdata.0.Küche.Siemens_Spülmaschine_Auto' /* Siemens Spülmaschine Auto */, false, true);
                      Hand = false;
                      if ((obj.state ? obj.state.val : '') == 3) {
                        Uhrzeit = true;
                      } else if ((obj.state ? obj.state.val : '') == 2) {
                        setState('0_userdata.0.Küche.Siemens_Spülmaschine_Auto' /* Siemens Spülmaschine Auto */, true, true);
                      } else if ((obj.state ? obj.state.val : '') == 1) {
                        Hand = true;
                        (() => { if (Auto_Ein_bei) { clearInterval(Auto_Ein_bei); Auto_Ein_bei = null; }})();
                        setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, true);
                      } else if ((obj.state ? obj.state.val : '') == 0) {
                        setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, false);
                      }
                    });
                    on({ id: [].concat(['0_userdata.0.Küche.Spülmaschine_Ein/Aus']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      Steckdose_Dauerein = false;
                      if ((obj.state ? obj.state.val : '') == 4) {
                        Steckdose_Dauerein = true;
                        setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, true);
                      }
                    });
                    on({ id: '0_userdata.0.Strom.Stromerzeugung_gesamt' /* Stromerzeugung gesamt */, change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      if (getState('0_userdata.0.Küche.Siemens_Spülmaschine_Auto').val == true) {
                        if ((obj.state ? obj.state.val : '') >= getState('0_userdata.0.Küche.Auto_ein_bei').val && getState('0_userdata.0.Strom.Batterie.Batterie___60%').val == true) {
                          setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, true);
                          setStateDelayed('0_userdata.0.Küche.Siemens_Spülmaschine_Auto_ein_bei' /* Siemens Spülmaschine Auto ein bei */, false, true, 120000, false);
                        }
                      }
                    });
                    on({ id: [].concat(['alias.0.Küche.Spülmaschine.SET']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      if ((obj.state ? obj.state.val : '') && getState('0_userdata.0.Küche.Spülmaschine_Ein/Aus').val != 1 && getState('0_userdata.0.Küche.Spülmaschine_Ein/Aus').val != 4) {
                        (() => { if (Wartezeit) { clearInterval(Wartezeit); Wartezeit = null; }})();
                        Wartezeit_Verbindungsaufbau = 90;
                        setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                        Wartezeit = setInterval(async () => {
                          Wartezeit_Verbindungsaufbau = (typeof Wartezeit_Verbindungsaufbau === 'number' ? Wartezeit_Verbindungsaufbau : 0) + -1;
                          setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                          if (Wartezeit_Verbindungsaufbau <= 0 && getState('alias.0.Küche.Spülmaschine.SET').val == true) {
                            (() => { if (Wartezeit) { clearInterval(Wartezeit); Wartezeit = null; }})();
                            setState('homeconnect.0.013060393307000289.programs.active.BSH_Common_Root_ActiveProgram' /* BSH_Common_Root_ActiveProgram */, 'Dishcare.Dishwasher.Program.Eco50');
                            setState('homeconnect.0.013060393307000289.settings.BSH_Common_Setting_PowerState' /* Energiezustand */, 'BSH.Common.EnumType.OperationState.On');
                            if (obj.id && obj?.state && !obj.state.ack) {
                              await setStateAsync(obj.id, { val: obj.state.val, ack: true });
                            }
                          }
                        }, 1000);
                      }
                      if ((obj.state ? obj.state.val : '') && getState('0_userdata.0.Küche.Spülmaschine_Ein/Aus').val == 1) {
                        (() => { if (Wartezeit3) { clearInterval(Wartezeit3); Wartezeit3 = null; }})();
                        Wartezeit_Verbindungsaufbau = 90;
                        setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                        Wartezeit3 = setInterval(async () => {
                          Wartezeit_Verbindungsaufbau = (typeof Wartezeit_Verbindungsaufbau === 'number' ? Wartezeit_Verbindungsaufbau : 0) + -1;
                          setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                          if (Wartezeit_Verbindungsaufbau <= 0) {
                            (() => { if (Wartezeit3) { clearInterval(Wartezeit3); Wartezeit3 = null; }})();
                          }
                        }, 1000);
                      }
                      if ((obj.state ? obj.state.val : '') && getState('0_userdata.0.Küche.Spülmaschine_Ein/Aus').val == 4) {
                        (() => { if (Wartezeit2) { clearInterval(Wartezeit2); Wartezeit2 = null; }})();
                        Wartezeit_Verbindungsaufbau = 90;
                        setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                        Wartezeit2 = setInterval(async () => {
                          Wartezeit_Verbindungsaufbau = (typeof Wartezeit_Verbindungsaufbau === 'number' ? Wartezeit_Verbindungsaufbau : 0) + -1;
                          setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                          if (Wartezeit_Verbindungsaufbau <= 0) {
                            (() => { if (Wartezeit2) { clearInterval(Wartezeit2); Wartezeit2 = null; }})();
                          }
                        }, 1000);
                      }
                    });
                    on({ id: [].concat(['homeconnect.0.013060393307000289.status.BSH_Common_Status_OperationState']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      if ((obj.state ? obj.state.val : '') == 'BSH.Common.EnumType.OperationState.Run' || (obj.state ? obj.state.val : '') == 'BSH.Common.EnumType.OperationState.Ready') {
                        setStateDelayed('0_userdata.0.Küche.Siemens_Spülmaschine_läuft' /* Siemens_Spülmaschine_läuft */, true, true, 30000, false);
                      }
                    });
                    on({ id: [].concat(['0_userdata.0.Küche.Siemens_Spülmaschine_Restlaufzeit']), change: 'ne' }, async (obj) => {
                      let value = obj.state.val;
                      let oldValue = obj.oldState.val;
                      if ((obj.state ? obj.state.val : '') <= 0 && getState('0_userdata.0.Küche.Siemens_Spülmaschine_läuft').val == true && getState('0_userdata.0.Küche.Siemens_Spülmaschine_Restlaufzeit').val <= 0) {
                        setState('0_userdata.0.Küche.Siemens_Spülmaschine_läuft' /* Siemens_Spülmaschine_läuft */, false, true);
                        setState('0_userdata.0.Küche.Spülmaschine_Ein/Aus' /* Spülmaschine Ein/Aus */, 0, true);
                        setStateDelayed('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, false, 300000, false);
                      }
                    });
                    
                    1 Antwort Letzte Antwort
                    0
                    • haus-automatisierungH haus-automatisierung

                      Kannst Du mal bitte das komplette Script zeigen? Da fehlt ja definitiv noch Code. Im Screenshot erkennt man ja einen weiteren Trigger usw.

                      @sms sagte in Object.<anonymous> finden?:

                      @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.

                      Das kann man schon so machen, aber schön/sauber ist das nicht. Ist zumindest nicht das Problem hier für die Fehlermeldung.

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

                      @haus-automatisierung sagte in Object.<anonymous> finden?:

                      Das kann man schon so machen

                      OT: Ich hatte mal einen Kollegen, der seinen Code eher so "hingerotzt" hat.
                      Für den hatte ich mir Spezialkleidung besorgt:
                      f88760af-bf71-4e22-a264-66f008ebb0be-image.png
                      Was soll ich sagen ... der war nicht mehr lange "Kollege" :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

                      SMSS 1 Antwort Letzte Antwort
                      0
                      • CodierknechtC Codierknecht

                        @haus-automatisierung sagte in Object.<anonymous> finden?:

                        Das kann man schon so machen

                        OT: Ich hatte mal einen Kollegen, der seinen Code eher so "hingerotzt" hat.
                        Für den hatte ich mir Spezialkleidung besorgt:
                        f88760af-bf71-4e22-a264-66f008ebb0be-image.png
                        Was soll ich sagen ... der war nicht mehr lange "Kollege" :grin:

                        SMSS Offline
                        SMSS Offline
                        SMS
                        schrieb am zuletzt editiert von
                        #15

                        @codierknecht Ich habe ja nicht gesagt das es perfekt ist. Das war für mich die Lösung damit da nicht 0 steht. Ich könnte natürlich auch einen Zahlenwert reinschreiben, den ich eh nie erreichen werde.

                        paul53P CodierknechtC 2 Antworten Letzte Antwort
                        0
                        • SMSS SMS

                          @codierknecht Ich habe ja nicht gesagt das es perfekt ist. Das war für mich die Lösung damit da nicht 0 steht. Ich könnte natürlich auch einen Zahlenwert reinschreiben, den ich eh nie erreichen werde.

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

                          @sms sagte: Das war für mich die Lösung damit da nicht 0 steht.

                          Wie wäre es mit Strings?

                          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

                          SMSS 1 Antwort Letzte Antwort
                          0
                          • paul53P paul53

                            @sms sagte: Das war für mich die Lösung damit da nicht 0 steht.

                            Wie wäre es mit Strings?

                            SMSS Offline
                            SMSS Offline
                            SMS
                            schrieb am zuletzt editiert von SMS
                            #17

                            @paul53 Wie müsste es dann aussehen? Trotzdem Zahlenwerte und true und false gemischt?

                            paul53P 1 Antwort Letzte Antwort
                            0
                            • SMSS SMS

                              @codierknecht Ich habe ja nicht gesagt das es perfekt ist. Das war für mich die Lösung damit da nicht 0 steht. Ich könnte natürlich auch einen Zahlenwert reinschreiben, den ich eh nie erreichen werde.

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

                              @sms sagte in Object.<anonymous> finden?:

                              Ich habe ja nicht gesagt das es perfekt ist

                              Deswegen ja auch "OT". War nicht an Dich adressiert.

                              Ich könnte natürlich auch einen Zahlenwert reinschreiben, den ich eh nie erreichen werde.

                              Wäre eine Möglichkeit.
                              Das Problem ist ja hier, dass eine rein Logische Aussage zusammen mit quantitativen Aussagen in einem einzigen DP zusammen abgebildet werden sollen.

                              @paul53 sagte in Object.<anonymous> finden?:

                              Wie wäre es mit Strings?

                              Fände ich fast noch unschöner.
                              Ich würde einen bestimmten - unter normalen Umständen niemals erreichbaren - Zahlenwert bevorzugen.

                              Oder aber z.B. -1 und diesen Sonderfall nochmal explizit prüfen, bevor da etwas losgetreten wird.
                              Alternative wäre ein Objekt. Mit "On/Off" als Bool und den Zahlenwerten als Number. Fände ich am saubersten.

                              "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

                              CodierknechtC 1 Antwort Letzte Antwort
                              0
                              • SMSS SMS

                                @paul53 Wie müsste es dann aussehen? Trotzdem Zahlenwerte und true und false gemischt?

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

                                @sms sagte: Wie müsste es dann aussehen?

                                Blockly_temp.JPG

                                Datenpunkt-Typ: "string".

                                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

                                SMSS 1 Antwort Letzte Antwort
                                0
                                • paul53P paul53

                                  @sms sagte: Wie müsste es dann aussehen?

                                  Blockly_temp.JPG

                                  Datenpunkt-Typ: "string".

                                  SMSS Offline
                                  SMSS Offline
                                  SMS
                                  schrieb am zuletzt editiert von
                                  #20

                                  @paul53 werde ich mal ausprobieren

                                  1 Antwort Letzte Antwort
                                  0
                                  • CodierknechtC Codierknecht

                                    @sms sagte in Object.<anonymous> finden?:

                                    Ich habe ja nicht gesagt das es perfekt ist

                                    Deswegen ja auch "OT". War nicht an Dich adressiert.

                                    Ich könnte natürlich auch einen Zahlenwert reinschreiben, den ich eh nie erreichen werde.

                                    Wäre eine Möglichkeit.
                                    Das Problem ist ja hier, dass eine rein Logische Aussage zusammen mit quantitativen Aussagen in einem einzigen DP zusammen abgebildet werden sollen.

                                    @paul53 sagte in Object.<anonymous> finden?:

                                    Wie wäre es mit Strings?

                                    Fände ich fast noch unschöner.
                                    Ich würde einen bestimmten - unter normalen Umständen niemals erreichbaren - Zahlenwert bevorzugen.

                                    Oder aber z.B. -1 und diesen Sonderfall nochmal explizit prüfen, bevor da etwas losgetreten wird.
                                    Alternative wäre ein Objekt. Mit "On/Off" als Bool und den Zahlenwerten als Number. Fände ich am saubersten.

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

                                    @codierknecht sagte in Object.<anonymous> finden?:

                                    Alternative wäre ein Objekt

                                    In etwa so:

                                    7437b5c3-672e-45b2-b181-e34d0bcc7c50-image.png
                                    Da hätte man Bool'sche und Zahlenwerte sauber getrennt.
                                    Kann man jetzt noch weiter optimieren, so dass das Objekt zur Laufzeit nur noch im RAM existiert und man das nicht ständig neu einlesen muss.

                                    "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

                                    SMSS 1 Antwort Letzte Antwort
                                    0
                                    • CodierknechtC Codierknecht

                                      @codierknecht sagte in Object.<anonymous> finden?:

                                      Alternative wäre ein Objekt

                                      In etwa so:

                                      7437b5c3-672e-45b2-b181-e34d0bcc7c50-image.png
                                      Da hätte man Bool'sche und Zahlenwerte sauber getrennt.
                                      Kann man jetzt noch weiter optimieren, so dass das Objekt zur Laufzeit nur noch im RAM existiert und man das nicht ständig neu einlesen muss.

                                      SMSS Offline
                                      SMSS Offline
                                      SMS
                                      schrieb am zuletzt editiert von
                                      #22

                                      @codierknecht Guten Morgen,

                                      ich habe mal die Variablen rausgemacht und etwas umprogrammiert, jetzt kommt die Meldung nicht mehr.

                                      Du hast zwar eine schöne Anleitung geschrieben, nur leider finde ich den Fall nicht den ich brauche:

                                      Funktioniert das hier so:
                                      52ecbabc-b937-4591-b584-624b517fda6c-grafik.png

                                      Ich möchte, wenn alle Stufen aus sind, das die Meldung "Heizstab eingeschaltet" weg geht.

                                      Oder ist es so besser:
                                      d8ae21eb-f363-4301-8a17-f8220da780ed-grafik.png

                                      Oder eine der beiden Varianten und bei "wurde geändert" "ist unwahr" auswählen und das "nicht" weg machen?

                                      Danke!

                                      CodierknechtC 1 Antwort Letzte Antwort
                                      0
                                      • SMSS SMS

                                        @codierknecht Guten Morgen,

                                        ich habe mal die Variablen rausgemacht und etwas umprogrammiert, jetzt kommt die Meldung nicht mehr.

                                        Du hast zwar eine schöne Anleitung geschrieben, nur leider finde ich den Fall nicht den ich brauche:

                                        Funktioniert das hier so:
                                        52ecbabc-b937-4591-b584-624b517fda6c-grafik.png

                                        Ich möchte, wenn alle Stufen aus sind, das die Meldung "Heizstab eingeschaltet" weg geht.

                                        Oder ist es so besser:
                                        d8ae21eb-f363-4301-8a17-f8220da780ed-grafik.png

                                        Oder eine der beiden Varianten und bei "wurde geändert" "ist unwahr" auswählen und das "nicht" weg machen?

                                        Danke!

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

                                        @sms
                                        Variante 1 auf keinen Fall.
                                        An einen Trigger kommen Objekt-ID's - kein bool'scher Ausdruck!

                                        Wir sind hier aber jetzt plötzlich bei einer völlig anderen Anwendung, oder?
                                        Was willst Du erreichen?

                                        "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

                                        SMSS 1 Antwort Letzte Antwort
                                        0
                                        • CodierknechtC Codierknecht

                                          @sms
                                          Variante 1 auf keinen Fall.
                                          An einen Trigger kommen Objekt-ID's - kein bool'scher Ausdruck!

                                          Wir sind hier aber jetzt plötzlich bei einer völlig anderen Anwendung, oder?
                                          Was willst Du erreichen?

                                          SMSS Offline
                                          SMSS Offline
                                          SMS
                                          schrieb am zuletzt editiert von SMS
                                          #24

                                          @codierknecht Ja andere Anwendung. Da ich aber gesehen habe das du eine Anleitung https://forum.iobroker.net/topic/70481/blockly-for-dummies-starthilfe-und-tipps geschrieben hast und man dort nicht antworten soll, dachte ich ich schreibe hier bevor ich ein neues Thema aufmache.

                                          Hier soll, sobald ein Heizstab angeht die Meldung "Heizstab eingeschaltet" ausgegeben werden:
                                          f848c27b-fac4-4c80-9e8b-ca3ba57e4523-grafik.png

                                          Sind alle Stufen aus, soll die Meldung wieder weg gehen.

                                          haus-automatisierungH HomoranH CodierknechtC 3 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

                                          908

                                          Online

                                          32.5k

                                          Benutzer

                                          81.9k

                                          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