Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [Vorlage] Stromverbrauch protokollieren - (etwas optimiert)

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    [Vorlage] Stromverbrauch protokollieren - (etwas optimiert)

    This topic has been deleted. Only users with topic management privileges can see it.
    • E
      ein-bayer last edited by

      Hallo allerseits,

      ich hab das script vor einer halben Stunde laufen lassen, soweit alles gut.

      Auffällig ist jedoch das mein LOG mit Fehlermeldungen vom history Adapter überläuft. Wenn ich das script pausiere sind die Meldungen weg.

      Weiß jemand woran das liegt?
      1342_log_verbrausz_hler.jpg

      1 Reply Last reply Reply Quote 0
      • Dutchman
        Dutchman Developer Most Active Administrators last edited by

        Ich sehe keine Fehlermeldung aber Meldungen das Datenpunkte geloggt werden?

        Sent from my iPhone using Tapatalk

        1 Reply Last reply Reply Quote 0
        • E
          ein-bayer last edited by

          Hallo Dutchman,

          Danke , ich habs falsch interpretiert weil´s beim Start so viele Meldungen waren und bei einem Zähler alias=false stand.

          1 Reply Last reply Reply Quote 0
          • Dutchman
            Dutchman Developer Most Active Administrators last edited by

            Ich würde mir an deiner Stelle auch abfragen ob du so viele Datenpunkte loggen musst.

            Von diesem Script loggen ich insgesamt 15 oder so und das reicht vollkommen

            Sent from my iPhone using Tapatalk

            1 Reply Last reply Reply Quote 0
            • W
              w00dy last edited by w00dy

              Hallo,

              wie @hg6806 habe ich ebenfalls das Problem, dass die ermittelten Werte um den Faktor +10 nicht stimmen.

              Ist es möglich, den Umrechnungsfaktor irgendwo im Script anzupassen?

              Im Script selber habe ich einen eigenen Datenpunkt angelegt. Dieser übernimmt Daten, die vom Modbus ermittelt werden.

              1 Reply Last reply Reply Quote 0
              • Dutchman
                Dutchman Developer Most Active Administrators last edited by

                Nein das kann das Script nicht.

                Ich würde es mit einem Script lösen welches erst den Wert mit Factor in einen anderen Datenpunkt schreiben und das Script auf diesen Datenpunkt loslassen

                Sent from my iPhone using Tapatalk

                1 Reply Last reply Reply Quote 0
                • W
                  w00dy last edited by w00dy

                  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.

                  1 Reply Last reply Reply Quote 0
                  • F
                    FriMatze last edited by

                    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?

                    Gruß
                    3311_52aa7b4f-8ff6-4f3d-aed9-2b6f528fa2ab.jpeg

                    1 Reply Last reply Reply Quote 0
                    • W
                      w00dy last edited by w00dy

                      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.

                      1 Reply Last reply Reply Quote 0
                      • hg6806
                        hg6806 Most Active last edited by

                        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?

                        1 Reply Last reply Reply Quote 0
                        • L
                          Linedancer last edited by

                          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.

                          1 Reply Last reply Reply Quote 0
                          • Dutchman
                            Dutchman Developer Most Active Administrators last edited by

                            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

                            1 Reply Last reply Reply Quote 0
                            • F
                              FriMatze last edited by

                              @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 :?

                              1 Reply Last reply Reply Quote 0
                              • D
                                Dice19 last edited by

                                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);
                                ! }
                                ! }
                                ! }

                                1 Reply Last reply Reply Quote 0
                                • Dutchman
                                  Dutchman Developer Most Active Administrators last edited by

                                  Hast du den in den datenobjecten Ruben kostpreis hinterlegt ?

                                  Sent from my iPhone using Tapatalk

                                  1 Reply Last reply Reply Quote 0
                                  • D
                                    Dice19 last edited by

                                    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

                                    1 Reply Last reply Reply Quote 0
                                    • sigi234
                                      sigi234 Forum Testing Most Active last edited by

                                      Preis mit PUNKT eingeben!

                                      2858_screenshot__1202__li.jpg

                                      1 Reply Last reply Reply Quote 0
                                      • SmarthomeMF
                                        SmarthomeMF last edited by

                                        Hallo

                                        Hört sich sehr interessant an.

                                        Werde ich auch mal ausprobieren

                                        1 Reply Last reply Reply Quote 0
                                        • D
                                          Dice19 last edited by

                                          Hab das ganze angepasst gestern, aber bisher erscheinen keine Preise….

                                          1 Reply Last reply Reply Quote 0
                                          • cvidal
                                            cvidal Forum Testing last edited by

                                            @tobih83:

                                            Hab das ganze angepasst gestern, aber bisher erscheinen keine Preise…. `

                                            Den Post von sigi234 zwei weiter oben habt du gesehen?

                                            Gruß Christian

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            752
                                            Online

                                            31.8k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            81
                                            455
                                            104913
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo