NEWS
Object.<anonymous> finden?
-
@codierknecht Da ich davon keine Ahnung habe, ... , nein es ist nicht gewollt. Wo ändere ich das?
-
@sms sagte in Object.<anonymous> finden?:
Wo ändere ich das?
In den Instanzeinstellungen (Expertenmodus)
-
@codierknecht was bedeutet debug?
-
@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ß. -
@codierknecht OK, danke!
Das eigentliche Problem liegt jetzt aber hier?
@codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.
Die Spülmaschine soll angehen, je nachdem welchen Wert ich einstelle und meine PV-Produktion diesen Wert überschreitet.
Das Ganze sieht so aus:
0 bedeutet = AUS
-
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.
-
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); } });
-
@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:
Was soll ich sagen ... der war nicht mehr lange "Kollege" -
@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.
-
@sms sagte: Das war für mich die Lösung damit da nicht 0 steht.
Wie wäre es mit Strings?
-
@paul53 Wie müsste es dann aussehen? Trotzdem Zahlenwerte und true und false gemischt?
-
@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. -
-
@paul53 werde ich mal ausprobieren
-
@codierknecht sagte in Object.<anonymous> finden?:
Alternative wäre ein Objekt
In etwa so:
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. -
@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:
Ich möchte, wenn alle Stufen aus sind, das die Meldung "Heizstab eingeschaltet" weg geht.
Oder ist es so besser:
Oder eine der beiden Varianten und bei "wurde geändert" "ist unwahr" auswählen und das "nicht" weg machen?
Danke!
-
@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? -
@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:
Sind alle Stufen aus, soll die Meldung wieder weg gehen.
-
@sms sagte in Object.<anonymous> finden?:
Hier soll, sobald ein Heizstab angeht die Meldung "Heizstab eingeschaltet" ausgegeben werden:
Dann musst Du auf das Zahnrad vor "Falls Objekte" klicken und mehr Trigger auf die andere Seite ziehen. Dann dort mehrere Objekt IDs angeben. Der Oder-Baustein hat dort nichts zu suchen.
-
@sms im Trigger niemals Logik!
nur IDsder Block WERT bezieht sich auf den Wert des Triggernden Datenpunkts.
was genau willst du mit dem Wert?