NEWS
[Vorlage] Stromverbrauch protokollieren - (etwas optimiert)
-
Hallo Dutchman,
daran habe ich auch schon gedacht, einfach den ermittelten Wert vom Modbus entsprechend anzupassen.
Da stoße ich aber mit meinen bescheidenen Blockly-Fähigkeiten an meine Grenzen.
Im Modbus-Adapter selber kann man zwar einen Faktor einstellen, allerdings fehlen dann die notwendigen Nachkommastellen, was die Sache dann sehr ungenau macht.
-
Moin in die Runde 8-)
Zum Script hätte ich eine kleine Frage. Die Daten werden soweit aufgezeichnet, doch wie auf dem Bild zu sehen nicht einzeln unter Tage und Wochen usw. und unter Zählerstände werden nur die kumulierten Werte aufgezeichnet jetzt frage ich mich natürlich warum?
-
Hallo,
sieht so aus, als ob der Adapter noch nicht genug Zeit hatte Daten zu sammeln.
Warte mal ein paar Tage ab, dann sollten Daten vorhanden sein.
-
So, Fehler wegen dem Faktor 10 gefunden!
Ich hatte beim Smartmeter
Momentanwert Gesamtwirkleistung (Total)
als Datenpunkt eingeben.
Richtig ist aber
Zählerstand 1 Summe Wirkarbeit Bezug + (Total)
Die beiden Smartemter geben kWh aus, also ist kumulierter Wert kWh = true
Blöderweise geben die Homematic Geräte aber Wh aus.
Muss das dann über
['Datenpunkt', 'Aliasname', 'Einheit kumulierter Wert', 'Einheit berechnete Werte (kilo/1000)' ],
korrigiert werden?
-
Ich rechne bei den Sonoff Pow mit einem separaten Script die kWh in Wh um und werfe diesen neuen Datenpunkt in das Verbrauchszähler Script.
-
OK sorry haste zuviel zu tun, brauche also kein blockly mehr zu Posten für den Factor 10 [emoji85]
Sent from my iPhone using Tapatalk
-
@Hicks:Hallo,
sieht so aus, als ob der Adapter noch nicht genug Zeit hatte Daten zu sammeln.
Warte mal ein paar Tage ab, dann sollten Daten vorhanden sein.
Gruß, Hicks `
Moin, immer noch keine Daten innerhalb der einzelnen Ordner :?
-
HI,
bei mir funktioniert die Strompreis berechnung nicht mehr.
kWh rechnet er zusammen aber keine €.
Vielleicht kann mal jemand drauf schauen er zeigt mir auch zig gelbe Warndreiecke an vor einigen Zeilen.
Danke
Tobias
! //jshint maxerr:1000
! // https://github.com/hdering/homematic_st … okollieren
! //----------------------------------------------------------------------------//
! // Version: 1.3.3
! //----------------------------------------------------------------------------//
! // +++++++++ USER ANPASSUNGEN ++++++++++++++++++++++++
! // debug logging
! var logging = true;
! // Aktivieren der History Instanz
! var enable_history = false;
! // history Instanz
! var instance_history = 'history.0';
! // Geräte können unterschiedliche Preise haben
! var enable_unterschiedlichePreise = false;
! // Speichern der Werte in zusätzlichen Objekten.
! // Wenn 0, dann deaktiviert
! var Tag_Anzahl_Werte_in_der_Vergangenheit = 7;
! var Woche_Anzahl_Werte_in_der_Vergangenheit = 4;
! var Monat_Anzahl_Werte_in_der_Vergangenheit = 12;
! var Quartal_Anzahl_Werte_in_der_Vergangenheit = 4;
! var Jahr_Anzahl_Werte_in_der_Vergangenheit = 2;
! // Grundpreis einberechnen
! var enable_Grundpreis_einberechnen = false;
! var instance = '0';
! var instanz = 'javascript.' + instance + '.';
! // Pfad innerhalb der Instanz
! var pfad = 'hm-rpc.2.XXXXXXXX.1.POWER';
! var default_unit = 'Wh';
! var default_unit_kilo = 'kWh';
! // Diese Teile werden aus den Gerätenamen entfernt
! var blacklist = [':1', ':2', ':3', ':4', ':5', ':6', ':7', ':8'];
! var AnzahlKommastellenKosten = 2;
! var AnzahlKommastellenVerbrauch = 3;
! var AnzahlKommastellenZaehlerstand = 3;
! var KumulierterWertIstBereitsInKilo = false;
! var eigeneDatenpunkte = [
! // Beispiel:
! // ['Datenpunkt', 'Aliasname', 'Einheit kumulierter Wert', 'Einheit berechnete Werte (kilo/1000)' ],
! // [ 'hm-rpc.2.XXXXXXXX.1.ENERGY_COUNTER', 'Stromzaehler:1.ENERGY_COUNTER', 'Wh', 'kWh' ],
! ];
! // Pushmeldung
! function send_message(text) {
! // Hier können die Pushmeldung über alle möglichen Wege verschickt werden.
! //console.log(text);
! //sendTelegram(text);
! }
! // ++++ ENDE USER ANPASSUNGEN ++++++++++++++++++++++++
! //–--------------------------------------------------------------------------//
! createState(pfad + 'Preis.aktuell.Arbeitspreis', {
! name: 'Strompreis - aktueller Arbeitspreis (brutto)',
! unit: '€/' + default_unit_kilo,
! type: 'number',
! def: 0,
! min: 0
! });
! createState(pfad + 'Preis.aktuell.Grundpreis', {
! name: 'Strompreis - aktueller Grundpreis (brutto)',
! unit: '€/Monat',
! type: 'number',
! def: 0,
! min: 0
! });
! //----------------------------------
! createState(pfad + 'Preis.neu.Arbeitspreis', {
! name: 'Strompreis - neuer Arbeitspreis ab Datum (brutto)',
! unit: '€/' + default_unit_kilo,
! type: 'number',
! def: 0,
! min: 0
! });
! createState(pfad + 'Preis.neu.Grundpreis', {
! name: 'Strompreis - neuer Grundpreis ab Datum (brutto)',
! unit: '€/Monat',
! type: 'number',
! def: 0,
! min: 0
! });
! createState(pfad + 'Preis.neu.Datum', {
! name: 'Strompreis und Grundpreis ab folgendem Datum zur Berechnung heranziehen (Beispiel 01.01.2019)',
! type: 'string',
! def: "01.01.1970",
! });
! createState(pfad + 'Preis.neu.PreisaenderungDurchgefuehrt', false, {
! read: true,
! write: true,
! type: "boolean",
! def: false
! });
! //----------------------------------------------------------------------------//
! var cacheSelectorStateMeter = $('channel[state.id=.METER]');
! var cacheSelectorStateEnergyCounter = $('channel[state.id=.ENERGY_COUNTER$]');
! //–--------------------------------------------------------------------------//
! function parseObjects(id) {
! var obj = getObject(id);
! return entferneDatenpunkt(obj.common.name);
! }
! function setRecognizedChange(type, anzahl) {
! cacheSelectorStateMeter.each(function (id, i) {
! var geraetename = parseObjects(id);
! rotateVerbrauchUndKosten(geraetename, type, anzahl);
! resetVerbrauchUndKosten(geraetename, type);
! schreibeZaehlerstand(geraetename, type);
! });
! cacheSelectorStateEnergyCounter.each(function (id, i) {
! var geraetename = parseObjects(id);
! rotateVerbrauchUndKosten(geraetename, type, anzahl);
! resetVerbrauchUndKosten(geraetename, type);
! schreibeZaehlerstand(geraetename, type);
! });
! if (eigeneDatenpunkte.length > 0) {
! for(var i = 0; i < eigeneDatenpunkte.length; i++) {
! var alias = eigeneDatenpunkte__[1];
! rotateVerbrauchUndKosten(alias, type, anzahl);
! resetVerbrauchUndKosten(alias, type);
! schreibeZaehlerstand(alias, type);
! }
! }
! }
! //–--------------------------------------------------------------------------//
! // Tageswechsel
! schedule("0 0 * * *", function() {
! setRecognizedChange('Tag', Tag_Anzahl_Werte_in_der_Vergangenheit);
! });
! // Wochenwechsel
! schedule("0 0 * * 1", function() {
! setRecognizedChange('Woche', Woche_Anzahl_Werte_in_der_Vergangenheit);
! });
! // Monatswechsel
! schedule("0 0 1 * *", function() {
! setRecognizedChange('Monat', Monat_Anzahl_Werte_in_der_Vergangenheit);
! });
! // Quartalswechsel
! schedule("0 0 1 */3 *", function() {
! setRecognizedChange('Quartal', Quartal_Anzahl_Werte_in_der_Vergangenheit);
! });
! // Jahreswechsel
! schedule("0 0 1 1 *", function() {
! setRecognizedChange('Jahr', Jahr_Anzahl_Werte_in_der_Vergangenheit);
! });
! //----------------------------------------------------------------------------//
! // Eigene Datenpunkte
! function pruefeEigeneDatenpunkte() {
! if (eigeneDatenpunkte.length > 0) {
! for(var i = 0; i < eigeneDatenpunkte.length; i++) {
! var datenpunkt = eigeneDatenpunkte__[0];
! var alias = eigeneDatenpunkte__[1];
! var einheit = eigeneDatenpunkte__[2];
! var einheit_kilo = eigeneDatenpunkte__[3];
! if(logging) console.log("Alias:" + alias + " Datenpunkt:" + datenpunkt + " Einheit:" + einheit + " Einheit_kilo:" + einheit_kilo);
! on(datenpunkt, function(obj) {
! for(var i = 0; i < eigeneDatenpunkte.length; i++) {
! if(eigeneDatenpunkte__[0] === obj.id)
! run(obj, eigeneDatenpunkte__[1], eigeneDatenpunkte__[2], eigeneDatenpunkte__[3]);
! }
! }
! }
! }
! }
! pruefeEigeneDatenpunkte();
! //–--------------------------------------------------------------------------//
! // Einlesen der aktuellen Daten vom Zähler
! function run(obj, alias, unit, unit_kilo) {
! if (logging) {
! log('-------- Strommesser ---------');
! log('RegExp-Funktion ausgelöst');
! log('id: ' + obj.id);
! log('Name: ' + obj.common.name); // Waschmaschine Küche:2.ENERGY_COUNTER
! log('channel ID: ' + obj.channelId); // hm-rpc.0.XXXXXXXX.2
! log('channel Name: ' + obj.channelName); // Waschmaschine Küche:2
! log('device ID: ' + obj.deviceId); // hm-rpc.0XXXXXXXXX
! log('device name: ' + obj.deviceName); // Küche Waschmaschine
! log('neuer Wert: ' + obj.newState.val); // 16499.699982
! log('alter Wert: ' + obj.oldState.val); // 16499.699982
! }
! // Gerätenamen erstellen
! if (logging) log('vor der Aufbereitung: ' + obj.common.name);
! var geraetename = entferneDatenpunkt(obj.common.name);
! if(typeof alias !== "undefined") {
! if(logging) console.log("Es wird der Aliasname gesetzt:" + alias);
! geraetename = alias;
! }
! if (logging) log('Nach der Aufbereitung: ' + geraetename);
! if(typeof geraetename !== "undefined") {
! //------------------------------------------------------------------------//
! _unit = default_unit;
! _unit_kilo = default_unit_kilo;
! // States erstellen (CreateStates für dieses Gerät)
! if(typeof unit !== "undefined") {
! unit = unit;
! }
! if(typeof unit_kilo !== "undefined") {
! unit_kilo = unit_kilo;
! }
! erstelleStates(geraetename, unit, unit_kilo);
! //------------------------------------------------------------------------//
! // Schreiben der neuen Werte
! var idKumuliert = instanz + pfad + geraetename + '.Zaehlerstand.kumuliert';
! var NeustartEventuellErkannt = false;
! var NeustartSicherErkannt = false;
! var oldState = obj.oldState.val;
! var newState = obj.newState.val;
! var difference = newState - oldState;
! if(difference > 0) {
! if(oldState !== 0) {
! // Kumulierten Wert mit Ist-Wert (inkl. Backup) synchronisieren
! var newValueKumuliert = getState(idKumuliert).val + difference;
! newValueKumuliert = parseFloat(newValueKumuliert);
! setState(idKumuliert, newValueKumuliert);
! } else {
! if(newState < getState(pfad + geraetename + '.config.NeustartErkanntAlterWert').val) {
! NeustartSicherErkannt = true;
! }
! }
! } else {
! // Fall 2 oder 3
! // Irgendetwas läuft außerplanmäßig. Wert wird sicherheitshalber gespeichert und nächster Lauf abgewartet
! NeustartEventuellErkannt = true;
! setState(pfad + geraetename + '.config.NeustartErkanntAlterWert', obj.oldState.val);
! }
! if(NeustartEventuellErkannt) {
! if(logging) {
! var message = geraetename + '\n'
! + 'Entweder die CCU oder Stromzähler wurden neugestartet/zurückgesetzt.\n'
! + 'Dieser Wert wird einmal ignoriert und auf den nächsten Wert gewartet.';
! send_message(message);
! }
! }
! if(NeustartSicherErkannt) {
! // zurücksetzen der Variable
! setState(pfad + geraetename + '.config.NeustartErkanntAlterWert', 0);
! //----------------------------------------------------------------//
! var message2 = geraetename + '\n'
! + 'Der Stromzähler (' + geraetename + ') ist übergelaufen, gelöscht oder neugestartet worden (ggf. Stromausfall).\n'
! + 'newState:' + obj.newState.val + '\n'
! + 'oldState:' + obj.oldState.val + '\n'
! + 'differenz:' + difference + '\n'
! + 'idKumuliert:' + getState(idKumuliert).val;
! send_message(message2);
! }
! //--------------------------------------------------------------------//
! pruefePreisaenderung();
! if(enable_unterschiedlichePreise)
! pruefePreisaenderung(geraetename);
! var idStrompreis = instanz + pfad + 'Preis.aktuell.Arbeitspreis';
! var idGrundpreis = instanz + pfad + 'Preis.aktuell.Grundpreis';
! // aktualisiere den Verbrauch und die Kosten
! if(KumulierterWertIstBereitsInKilo)
! zaehler = (getState(idKumuliert).val).toFixed(AnzahlKommastellenZaehlerstand);
! else
! zaehler = (getState(idKumuliert).val / 1000).toFixed(AnzahlKommastellenZaehlerstand);
! preis = getState(idStrompreis).val;
! grundpreis = getState(idGrundpreis).val;
! // Wenn das Gerät einen eigenen Strompreis / Grundpreis hat
! if(enable_unterschiedlichePreise) {
! if(getState(instanz + pfad + geraetename + '.eigenerPreis.aktuell.Arbeitspreis').val > 0) {
! preis = getState(instanz + pfad + geraetename + '.eigenerPreis.aktuell.Arbeitspreis').val;
! if (logging) console.log("Das Gerät:" + geraetename + " hat eigenen Strompreis: " + preis);
! }
! if(getState(instanz + pfad + geraetename + '.eigenerPreis.aktuell.Grundpreis').val > 0) {
! grundpreis = getState(instanz + pfad + geraetename + '.eigenerPreis.aktuell.Grundpreis').val;
! if (logging) console.log("Das Gerät:" + geraetename + " hat eigenen Grundpreis: " + grundpreis);
! }
! }
! berechneVerbrauchUndKosten(geraetename, zaehler, preis, grundpreis); // in kWh
! if (logging) log('------------ ENDE ------------');
! } else {
! var message3 = 'Fehler beim Erstellen des Gerätenamens:\n'
! + 'obj.common.name: ' + obj.common.name;
! send_message(message3);
! }
! }
! cacheSelectorStateMeter.on(function(obj) {
! run(obj);
! });
! cacheSelectorStateEnergyCounter.on(function(obj) {
! run(obj);
! });
! //----------------------------------------------------------------------------//
! function entferneDatenpunkt(geraet) {
! var rueckgabe = geraet;
! // ":2.ENERGY_COUNTER" --> ".ENERGY_COUNTER"
! if (geraet.indexOf(".ENERGY_COUNTER") != -1) {
! rueckgabe = geraet.substring(0, geraet.indexOf(".ENERGY_COUNTER"));
! } else if (geraet.indexOf(".METER") != -1) {
! rueckgabe = geraet.substring(0, geraet.indexOf(".METER"));
! }
! if (logging) log('entferneDatenpunkt - rueckgabe1:' + rueckgabe);
! // Rückgabe sollte keine Sonderzeichen oder Leerzeichen enthalten. Wenn doch, werden die entfernt oder ersetzt
! try {
! rueckgabe = checkBlacklist(rueckgabe);
! }
! catch(err) {
! if (logging) log('entferneDatenpunkt - rueckgabe2:' + rueckgabe + ' error:' + err);
! }
! finally {
! if (logging) log('entferneDatenpunkt - rueckgabe2:' + rueckgabe);
! }
! try {
! if (rueckgabe.charAt(rueckgabe.length - 1) == "-") rueckgabe = rueckgabe.substr(0, rueckgabe.length - 1);
! if (rueckgabe.charAt(rueckgabe.length - 1) == "\") rueckgabe = rueckgabe.substr(0, rueckgabe.length - 1);
! if (rueckgabe.charAt(rueckgabe.length - 1) == ":") rueckgabe = rueckgabe.substr(0, rueckgabe.length - 1);
! }
! catch(err) {
! if (logging) log('entferneDatenpunkt - rueckgabe3:' + rueckgabe + ' error:' + err);
! }
! finally {
! if (logging) log('entferneDatenpunkt - rueckgabe3:' + rueckgabe);
! }
! // per Regexp Leerzeichen entfernen
! try {
! rueckgabe = rueckgabe.replace(/\s/g, "");
! }
! catch(err) {
! if (logging) log('entferneDatenpunkt - rueckgabe4:' + rueckgabe + ' error:' + err);
! }
! finally {
! if (logging) log('entferneDatenpunkt - rueckgabe4:' + rueckgabe);
! }
! return rueckgabe;
! }
! function checkBlacklist(name) {
! var name = "";
! if (blacklist.length > 0) {
! for(var i = 0; i < blacklist.length; i++) {
! if (name.indexOf(blacklist) != -1) {
! // Zeichenketten, die in der Blacklist stehen, aus dem Namen löschen
! name = name.substring(0, name.indexOf(blacklist));
! }
! }
! if(name === "") {
! return name;
! } else {
! return name;
! }
! } else return (name);
! }
! function schreibeZaehlerstand(geraet, zeitraum) {
! var idKumuliert = instanz + pfad + geraet + '.Zaehlerstand.kumuliert',
! idZaehlerstand = instanz + pfad + geraet + '.Zaehlerstand.' + zeitraum;
! // Zählerstand für übergebene Zeitraum und das Gerät in Wh auslesen und in kWh speichern (also durch 1000)
! if(KumulierterWertIstBereitsInKilo)
! setState(idZaehlerstand, parseFloat( (getState(idKumuliert).val).toFixed(AnzahlKommastellenZaehlerstand)) );
! else
! setState(idZaehlerstand, parseFloat( (getState(idKumuliert).val / 1000).toFixed(AnzahlKommastellenZaehlerstand)) );
! if (logging) log('Zählerstände für das Gerät ' + geraet + ' (' + zeitraum + ') in Objekten gespeichert');
! }
! function rotateVerbrauchUndKosten(geraet, zeitraum, anzahl) {
! // Verbrauch
! if(anzahl > 0) {
! for(var i = anzahl; i >= 0; i–) {
! var j = i;
! j++;
! if(getObject(instanz + pfad + geraet + '.Verbrauch.' + zeitraum + '.' + zeitraum + '' + j)) {
! if(i === 0)
! setState(instanz + pfad + geraet + '.Verbrauch.' + zeitraum + '.' + zeitraum + '' + j, getState(instanz + pfad + geraet + '.Verbrauch.' + zeitraum).val);
! else
! setState(instanz + pfad + geraet + '.Verbrauch.' + zeitraum + '.' + zeitraum + '' + j, getState(instanz + pfad + geraet + '.Verbrauch.' + zeitraum + '.' + zeitraum + '' + i).val);
! }
! }
! }
! // Kosten
! if(anzahl > 0) {
! for(var i = anzahl; i >= 0; i--) {
! var j = i;
! j++;
! if(getObject(instanz + pfad + geraet + '.Kosten.' + zeitraum + '.' + zeitraum + '' + j)) {
! if(i === 0)
! setState(instanz + pfad + geraet + '.Kosten.' + zeitraum + '.' + zeitraum + '' + j, getState(instanz + pfad + geraet + '.Kosten.' + zeitraum).val);
! else
! setState(instanz + pfad + geraet + '.Kosten.' + zeitraum + '.' + zeitraum + '' + j, getState(instanz + pfad + geraet + '.Kosten.' + zeitraum + '.' + zeitraum + '' + i).val);
! }
! }
! }
! }
! function resetVerbrauchUndKosten(geraet, zeitraum) {
! // Reset der Stromkosten für den übergebenen Zeitraum
! // Reset des Stromverbrauchs für den übergebenen Zeitraum
! setState(instanz + pfad + geraet + '.Kosten.' + zeitraum, 0);
! setState(instanz + pfad + geraet + '.Verbrauch.' + zeitraum, 0);
! if (logging) log('Stromkosten und Stromverbrauch für das Gerät ' + geraet + ' (' + zeitraum + ') zurückgesetzt');
! }
! function berechneVerbrauchUndKosten(geraet, zaehler, preis, grundpreis) {
! // bei jedem eingehenden Wert pro Gerät
! if(preis === 0) {
! var message0 = 'Achtung!' + '.\n'
! + 'Es wurde noch kein Arbeitspreis angegeben.' + '\n'
! + 'Ohne Arbeitspreis kann das Skript keine Berechnungen durchführen.' + '\n'
! + 'Diese Information ist zwingend notwendig!';
! log(message0, 'error');
! } else {
! var _grundpreis = 0;
! if(enable_Grundpreis_einberechnen) {
! _grundpreis = grundpreis * 12 / 365;
! _grundpreis = parseFloat(_grundpreis.toFixed(3));
! }
! grundpreis_tag = _grundpreis;
! grundpreis_woche = _grundpreis * 7;
! grundpreis_monat = _grundpreis * 30;
! grundpreis_quartal = _grundpreis * 90;
! grundpreis_jahr = _grundpreis * 365;
! // Tag [Verbrauchskosten = (Zähler_ist - Zähler_Tagesbeginn) * Preis ] –- zaehler muss immer größer sein als Tages, Wochen, etc.-Wert
! setState(instanz + pfad + geraet + '.Kosten.Tag', parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Tag').val) * preis) + grundpreis_tag).toFixed(AnzahlKommastellenKosten) ) ); // Kosten an diesem Tag in €
! // Woche
! setState(instanz + pfad + geraet + '.Kosten.Woche', parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Woche').val) * preis) + grundpreis_woche).toFixed(AnzahlKommastellenKosten) ) );
! // Monat
! setState(instanz + pfad + geraet + '.Kosten.Monat', parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Monat').val) * preis) + grundpreis_monat).toFixed(AnzahlKommastellenKosten) ) );
! // Quartal
! setState(instanz + pfad + geraet + '.Kosten.Quartal', parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Quartal').val) * preis) + grundpreis_quartal).toFixed(AnzahlKommastellenKosten) ) );
! // Jahr
! setState(instanz + pfad + geraet + '.Kosten.Jahr', parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Jahr').val) * preis) + grundpreis_jahr).toFixed(AnzahlKommastellenKosten) ) );
! if (logging) log('Stromkosten (' + geraet + ') aktualisiert');
! }
! // Verbrauch berechnen
! // Tag [Verbrauchskosten = (Zähler_ist - Zähler_Tagesbeginn) * Preis ] –- zaehler muss immer größer sein als Tages, Wochen, etc.-Wert
! setState(instanz + pfad + geraet + '.Verbrauch.Tag', parseFloat( (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Tag').val).toFixed(AnzahlKommastellenVerbrauch) ) ); // Verbrauch an diesem Tag in kWh
! // Woche
! setState(instanz + pfad + geraet + '.Verbrauch.Woche', parseFloat( (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Woche').val).toFixed(AnzahlKommastellenVerbrauch) ) );
! // Monat
! setState(instanz + pfad + geraet + '.Verbrauch.Monat', parseFloat( (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Monat').val).toFixed(AnzahlKommastellenVerbrauch) ) );
! // Quartal
! setState(instanz + pfad + geraet + '.Verbrauch.Quartal', parseFloat( (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Quartal').val).toFixed(AnzahlKommastellenVerbrauch) ) );
! // Jahr
! setState(instanz + pfad + geraet + '.Verbrauch.Jahr', parseFloat( (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Jahr').val).toFixed(AnzahlKommastellenVerbrauch) ) );
! if (logging) log('Stromverbrauch (' + geraet + ') aktualisiert');
! }
! function erstelleStates (geraet, _unit, _unit_kilo) {
! // Kumulierter Zählerstand (wird nie kleiner)
! createState(pfad + geraet + '.Zaehlerstand.kumuliert', 0, {name: 'Kumulierter Zählerstand (' + geraet + ')', type: 'number', unit: _unit });
! // Zählerstand
! createState(pfad + geraet + '.Zaehlerstand.Tag', 0, {name: 'Zählerstand Tagesbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Zaehlerstand.Woche', 0, {name: 'Zählerstand Wochenbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Zaehlerstand.Monat', 0, {name: 'Zählerstand Monatsbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Zaehlerstand.Quartal', 0, {name: 'Zählerstand Quartalsbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Zaehlerstand.Jahr', 0, {name: 'Zählerstand Jahresbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! // Verbrauch
! createState(pfad + geraet + '.Verbrauch.Tag', 0, {name: 'Verbrauch seit Tagesbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Verbrauch.Woche', 0, {name: 'Verbrauch seit Wochenbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Verbrauch.Monat', 0, {name: 'Verbrauch seit Monatsbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Verbrauch.Quartal', 0, {name: 'Verbrauch seit Quartalsbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Verbrauch.Jahr', 0, {name: 'Verbrauch seit Jahresbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
! // Stromkosten
! createState(pfad + geraet + '.Kosten.Tag', 0, {name: 'Stromkosten heute (' + geraet + ')', type: 'number', unit: '€' });
! createState(pfad + geraet + '.Kosten.Woche', 0, {name: 'Stromkosten Woche (' + geraet + ')', type: 'number', unit: '€' });
! createState(pfad + geraet + '.Kosten.Monat', 0, {name: 'Stromkosten Monat (' + geraet + ')', type: 'number', unit: '€' });
! createState(pfad + geraet + '.Kosten.Quartal', 0, {name: 'Stromkosten Quartal (' + geraet + ')', type: 'number', unit: '€' });
! createState(pfad + geraet + '.Kosten.Jahr', 0, {name: 'Stromkosten Jahr (' + geraet + ')', type: 'number', unit: '€' });
! // Speichern der Werte in zusätzlichen Variablen
! if(Tag_Anzahl_Werte_in_der_Vergangenheit > 0) {
! for(var i = 1; i <= Tag_Anzahl_Werte_in_der_Vergangenheit; i++) {
! createState(pfad + geraet + '.Verbrauch.Tag.Tag' + i, 0, {name: 'Verbrauch vor ' + i + ' Tag(en) (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Kosten.Tag.Tag' + i, 0, {name: 'Stromkosten vor ' + i + ' Tag(en) (' + geraet + ')', type: 'number', unit:'€' });
! }
! }
! if(Woche_Anzahl_Werte_in_der_Vergangenheit > 0) {
! for(var i = 1; i <= Woche_Anzahl_Werte_in_der_Vergangenheit; i++) {
! createState(pfad + geraet + '.Verbrauch.Woche.Woche' + i, 0, {name: 'Verbrauch vor ' + i + ' Woche(n) (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Kosten.Woche.Woche' + i, 0, {name: 'Stromkosten vor ' + i + ' Woche(n) (' + geraet + ')', type: 'number', unit:'€' });
! }
! }
! if(Monat_Anzahl_Werte_in_der_Vergangenheit > 0) {
! for(var i = 1; i <= Monat_Anzahl_Werte_in_der_Vergangenheit; i++) {
! createState(pfad + geraet + '.Verbrauch.Monat.Monat' + i, 0, {name: 'Verbrauch vor ' + i + ' Monat(en) (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Kosten.Monat.Monat' + i, 0, {name: 'Stromkosten vor ' + i + ' Monat(en) (' + geraet + ')', type: 'number', unit:'€' });
! }
! }
! if(Quartal_Anzahl_Werte_in_der_Vergangenheit > 0) {
! for(var i = 1; i <= Quartal_Anzahl_Werte_in_der_Vergangenheit; i++) {
! createState(pfad + geraet + '.Verbrauch.Quartal.Quartal' + i, 0, {name: 'Verbrauch vor ' + i + ' Quartal(en) (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Kosten.Quartal.Quartal' + i, 0, {name: 'Stromkosten vor ' + i + ' Quartal(en) (' + geraet + ')', type: 'number', unit:'€' });
! }
! }
! if(Jahr_Anzahl_Werte_in_der_Vergangenheit > 0) {
! for(var i = 1; i <= Jahr_Anzahl_Werte_in_der_Vergangenheit; i++) {
! createState(pfad + geraet + '.Verbrauch.Jahr.Jahr' + i, 0, {name: 'Verbrauch vor ' + i + ' Jahr(en) (' + geraet + ')', type: 'number', unit: _unit_kilo });
! createState(pfad + geraet + '.Kosten.Jahr.Jahr' + i, 0, {name: 'Stromkosten vor ' + i + ' Jahr(en) (' + geraet + ')', type: 'number', unit:'€' });
! }
! }
! // Neustart von CCU oder Gerät erkannt
! createState(pfad + geraet + '.config.NeustartErkanntAlterWert', 0);
! // Gerät hat eigenen Strompreis
! if(enable_unterschiedlichePreise) {
! createState(pfad + geraet + '.eigenerPreis.aktuell.Arbeitspreis' , { name: 'Strompreis - aktueller Arbeitspreis ab Datum (brutto)' , unit: '€/' + _unit_kilo, type: 'number', def: 0 });
! createState(pfad + geraet + '.eigenerPreis.aktuell.Grundpreis' , { name: 'Strompreis - aktueller Grundpreis ab Datum (brutto)' , unit: '€/Monat', type: 'number', def: 0 });
! createState(pfad + geraet + '.eigenerPreis.neu.Arbeitspreis' , { name: 'Strompreis - neuer Arbeitspreis ab Datum (brutto)' , unit: '€/' + _unit_kilo, type: 'number', def: 0 });
! createState(pfad + geraet + '.eigenerPreis.neu.Grundpreis' , { name: 'Strompreis - neuer Grundpreis ab Datum (brutto)' , unit: '€/Monat', type: 'number', def: 0 });
! createState(pfad + geraet + '.eigenerPreis.neu.Datum' , { name: 'Strompreis und Grundpreis ab folgendem Datum zur Berechnung heranziehen (Beispiel 01.01.2019)', def: "01.01.1970", type: 'string' });
! createState(pfad + geraet + '.eigenerPreis.neu.PreisaenderungDurchgefuehrt' , false, { read: true, write: true, type: "boolean", def: false });
! }
! // history bei allen Datenpunkten aktivieren
! if(enable_history) {
! enableHistory(geraet, 'Tag');
! enableHistory(geraet, 'Woche');
! enableHistory(geraet, 'Monat');
! enableHistory(geraet, 'Quartal');
! enableHistory(geraet, 'Jahr');
! }
! if (logging) log('States in der Instanz ' + instanz + pfad + ' erstellt');
! }
! function enableHistory(geraet, zeitraum) {
! if(instance_history !== '') {
! sendTo(instance_history, 'enableHistory', {
! id: instanz + pfad + geraet + '.Kosten.' + zeitraum,
! options: {
! changesOnly: true,
! debounce: 0,
! retention: 31536000,
! maxLength: 3,
! changesMinDelta: 0.5
! }
! }, function (result) {
! if (result.error) {
! if (logging) log("Fehler beim Aktivieren von History: " + result.error);
! }
! });
! sendTo(instance_history, 'enableHistory', {
! id: instanz + pfad + geraet + '.Verbrauch.' + zeitraum,
! options: {
! changesOnly: true,
! debounce: 0,
! retention: 31536000,
! maxLength: 3,
! changesMinDelta: 0.5
! }
! }, function (result) {
! if (result.error) {
! if (logging) log("Fehler beim Aktivieren von History: " + result.error);
! }
! });
! sendTo(instance_history, 'enableHistory', {
! id: instanz + pfad + geraet + '.Zaehlerstand.' + zeitraum,
! options: {
! changesOnly: true,
! debounce: 0,
! retention: 31536000,
! maxLength: 3,
! changesMinDelta: 0.5
! }
! }, function (result) {
! if (result.error) {
! if (logging) log("Fehler beim Aktivieren von History: " + result.error);
! }
! });
! }
! }
! function pruefePreisaenderung(geraet) {
! var _Datum = "";
! var _PreisaenderungDurchgefuehrt = "";
! var _Arbeitspreis = "";
! var _Grundpreis = "";
! var _ArbeitspreisNeu = "";
! var _GrundpreisNeu = "";
! if(typeof geraet === "undefined") {
! // Default Arbeitspreis ändern
! _Datum = instanz + pfad + 'Preis.neu.Datum';
! _PreisaenderungDurchgefuehrt = instanz + pfad + 'Preis.neu.PreisaenderungDurchgefuehrt';
! Arbeitspreis = instanz + pfad + 'Preis.aktuell.Arbeitspreis';
! Grundpreis = instanz + pfad + 'Preis.aktuell.Grundpreis';
! ArbeitspreisNeu = instanz + pfad + 'Preis.neu.Arbeitspreis';
! GrundpreisNeu = instanz + pfad + 'Preis.neu.Grundpreis';
! } else {
! // Arbeitspreis für Gerät ändern
! Datum = instanz + pfad + geraet + '.eigenerPreis.neu.Datum';
! PreisaenderungDurchgefuehrt = instanz + pfad + geraet + '.eigenerPreis.neu.PreisaenderungDurchgefuehrt';
! Arbeitspreis = instanz + pfad + geraet + '.eigenerPreis.aktuell.Arbeitspreis';
! Grundpreis = instanz + pfad + geraet + '.eigenerPreis.aktuell.Grundpreis';
! ArbeitspreisNeu = instanz + pfad + geraet + '.eigenerPreis.neu.Arbeitspreis';
! GrundpreisNeu = instanz + pfad + geraet + '.eigenerPreis.neu.Grundpreis';
! }
! if(getObject(Datum)) {
! var date = getState(Datum).val;
! var Datum_Tag;
! var Datum_Monat;
! var Datum_Jahr;
! try {
! var Datum = date.match(/\d{2}(.|-)\d{2}(.|-)\d{4}/g).toString();
! Datum_Tag = Datum.split(".")[0];
! Datum_Monat = Datum.split(".")[1];
! Datum_Jahr = Datum.split(".")[2];
! } catch (err) {
! console.log("Fehler beim Auslesen des Datums. Eventuell falsche Syntax? " + date + " (Error:" + err + ")");
! }
! newdate = new Date(Datum_Monat + " " + Datum_Tag + " " + Datum_Jahr);
! var today = new Date();
! today.setHours(0,0,0,0);
! if(today.getTime() === newdate.getTime()) {
! if(!getState(PreisaenderungDurchgefuehrt).val) {
! setState(PreisaenderungDurchgefuehrt, true);
! var alterArbeitspreis = getState(Arbeitspreis).val;
! var alterGrundpreis = getState(Grundpreis).val;
! var neuerArbeitspreis = getState(ArbeitspreisNeu).val;
! var neuerGrundpreis = getState(GrundpreisNeu).val;
! setState(Arbeitspreis, neuerArbeitspreis);
! setState(Grundpreis, neuerGrundpreis);
! var message = 'Preisänderung für ' + geraet + ' wurde durchgeführt:' + '\n'
! + 'alter Arbeitspreis:' + alterArbeitspreis + '.\n'
! + 'alter Grundpeis:' + alterGrundpreis + '.\n'
! + 'neuer Arbeitspreis:' + neuerArbeitspreis + '.\n'
! + 'neuer Grundpreis:' + neuerGrundpreis;
! send_message(message);
! }
! } else if(today.getTime() > newdate.getTime()) {
! // Variable zurücksetzen
! setState(PreisaenderungDurchgefuehrt, false);
! }
! }
! } -
Hast du den in den datenobjecten Ruben kostpreis hinterlegt ?
Sent from my iPhone using Tapatalk
-
Muss ich das hier ändern?
Wenn ich bei def: hinter dem 0, was eintrage erscheint ein rotes Kreuz.
createState(pfad + 'Preis.aktuell.Arbeitspreis', {
name: 'Strompreis - aktueller Arbeitspreis (brutto)',
unit: '€/' + default_unit_kilo,
type: 'number',
def: 0,
min: 0
});
createState(pfad + 'Preis.aktuell.Grundpreis', {
name: 'Strompreis - aktueller Grundpreis (brutto)',
unit: '€/Monat',
type: 'number',
def: 0,
min: 0
-
Preis mit PUNKT eingeben!
-
Hallo
Hört sich sehr interessant an.
Werde ich auch mal ausprobieren
-
Hab das ganze angepasst gestern, aber bisher erscheinen keine Preise….
-
@tobih83:Hab das ganze angepasst gestern, aber bisher erscheinen keine Preise…. `
Den Post von sigi234 zwei weiter oben habt du gesehen?
Gruß Christian
-
Ja….
-
NICHT im Script eintragen sondern unter OBJEKTE! (javascript.0. - Verbrauchszaehler - Preis - Aktuell = 0.27 darunter Grundpreis= 8.0 ) oder wie dein Grundpreis eben ist.
-
Hallo Gemeinde,
hab mal wieder eine Frage wie oder wo muss ich in dem Script was einfügen, ich bekomme meine Daten über einen Pulscounter ich habe auch alles schon in Watt und kW mit einem Script umgerechnet.
bekomme aber keine Daten geliefert.
-
321 Beiträge! Puh viel zu lesen.
Ein Adapter ist noch nicht geplant für das Script oder?
Gruss
-
Hallo,
erstmal danke für das tolle script!!!
Läuft bei mir vorzüglich bis auf ein kleines Problem.
Habe als history Adapter nun zu sql gewechselt.
Seit dem gibts bei mir im log folgende Fehlermeldungen:
2018-12-06 17:23:25.771 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=91 AND ts < 1512577380763;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist 2018-12-06 17:23:25.771 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=89 AND ts < 1512577380763;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist 2018-12-06 17:23:25.772 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=81 AND ts < 1512577380764;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist 2018-12-06 17:23:25.772 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=90 AND ts < 1512577380764;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist 2018-12-06 17:23:25.772 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=84 AND ts < 1512577380764;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist 2018-12-06 17:23:25.773 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=88 AND ts < 1512577380765;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist 2018-12-06 17:23:25.773 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=92 AND ts < 1512577380765;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist 2018-12-06 17:23:25.773 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=93 AND ts < 1512577380763;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist 2018-12-06 17:23:25.775 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=87 AND ts < 1512577380769;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
Wie bekomme ich die raus?
-
Welchen Wert von meinem Discovergy Zähler muss ich eintragen das das Script ordentlich zählt und Rechnet?
Den Aktuellen Verbrauch oder den Zählerstand?
Gruß Danyel