Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [Vorlage] Stromverbrauch protokollieren - (etwas optimiert)

NEWS

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

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

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

[Vorlage] Stromverbrauch protokollieren - (etwas optimiert)

Geplant Angeheftet Gesperrt Verschoben JavaScript
455 Beiträge 81 Kommentatoren 117.0k Aufrufe 36 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • Lenny.CBL Offline
    Lenny.CBL Offline
    Lenny.CB
    Most Active
    schrieb am zuletzt editiert von
    #294

    @hg6806:

    Sucht es automatisch nach Homematic Leistungsmessern? ` Das war bei mir auch so. Ich glaube https://github.com/hdering/homematic_verbrauchszaehler/blob/master/Zaehlerstande_protokollieren.js#L231 passiert das.

    1 Antwort Letzte Antwort
    0
    • hg6806H Offline
      hg6806H Offline
      hg6806
      Most Active
      schrieb am zuletzt editiert von
      #295

      OK, das kann gut sein mit dem Homematic Leistungsmesser.

      Aber woher kommt der Fehler mit dem Faktor 10?

      Klar könnte ich das schnell fixen, mich würde aber interessieren wo das her kommt.

      1 Antwort Letzte Antwort
      0
      • hg6806H Offline
        hg6806H Offline
        hg6806
        Most Active
        schrieb am zuletzt editiert von
        #296

        Ich muss mich korrigieren. Beide Smartmeter werden um Faktor 10 falsch gezählt.

        1 Antwort Letzte Antwort
        0
        • hg6806H Offline
          hg6806H Offline
          hg6806
          Most Active
          schrieb am zuletzt editiert von
          #297

          Guten Morgen,

          kann hier bitte jemand helfen?

          Stromverbrauch wird noch immer um groben Faktor 10 falsch gezählt.

          Es wird im Skript mehr gezählt als tatsächlich verbraucht.

          Ich habe lediglich das Skript genommen und meine beiden IR-USB Smartmeter inkludiert.

          Danke für Hinweise!

          1 Antwort Letzte Antwort
          0
          • K Offline
            K Offline
            knudi76
            schrieb am zuletzt editiert von
            #298

            Hallo Forengemeinde,

            ich versuche mich gerade an diesem Script, leider bekomme ich von meiner PV-Anlage nur die Leistungswerte und keine Energiewerte. Diese benötige ich aber damit dieses Script funktioniert. Ich habe bislang im Forum nur etwas zur Umrechung von Energie zu Leistung gefunden. Gibt es eine Möglichkeit die Leistung auf Wertänderung zu prüfen und diese dann über die verstrichende Zeit in Energie zu berechnen? Diese Energie kann ich dann vernünftig in dieses Script einfügen und so meinen Ertrag protokollieren.

            Vielen Dank

            Stephan

            1 Antwort Letzte Antwort
            0
            • E Offline
              E Offline
              ein-bayer
              schrieb am zuletzt editiert von
              #299

              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 Antwort Letzte Antwort
              0
              • DutchmanD Offline
                DutchmanD Offline
                Dutchman
                Developer Most Active Administrators
                schrieb am zuletzt editiert von
                #300

                Ich sehe keine Fehlermeldung aber Meldungen das Datenpunkte geloggt werden?

                Sent from my iPhone using Tapatalk

                1 Antwort Letzte Antwort
                0
                • E Offline
                  E Offline
                  ein-bayer
                  schrieb am zuletzt editiert von
                  #301

                  Hallo Dutchman,

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

                  1 Antwort Letzte Antwort
                  0
                  • DutchmanD Offline
                    DutchmanD Offline
                    Dutchman
                    Developer Most Active Administrators
                    schrieb am zuletzt editiert von
                    #302

                    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 Antwort Letzte Antwort
                    0
                    • W Offline
                      W Offline
                      w00dy
                      schrieb am zuletzt editiert von w00dy
                      #303

                      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.

                      LG,
                      w00dy

                      1 Antwort Letzte Antwort
                      0
                      • DutchmanD Offline
                        DutchmanD Offline
                        Dutchman
                        Developer Most Active Administrators
                        schrieb am zuletzt editiert von
                        #304

                        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 Antwort Letzte Antwort
                        0
                        • W Offline
                          W Offline
                          w00dy
                          schrieb am zuletzt editiert von w00dy
                          #305

                          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.

                          LG,
                          w00dy

                          1 Antwort Letzte Antwort
                          0
                          • F Offline
                            F Offline
                            FriMatze
                            schrieb am zuletzt editiert von
                            #306

                            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 Antwort Letzte Antwort
                            0
                            • W Offline
                              W Offline
                              w00dy
                              schrieb am zuletzt editiert von w00dy
                              #307

                              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.

                              LG,
                              w00dy

                              1 Antwort Letzte Antwort
                              0
                              • hg6806H Offline
                                hg6806H Offline
                                hg6806
                                Most Active
                                schrieb am zuletzt editiert von
                                #308

                                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 Antwort Letzte Antwort
                                0
                                • L Offline
                                  L Offline
                                  Linedancer
                                  schrieb am zuletzt editiert von
                                  #309

                                  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.

                                  –

                                  Ciao, Gerhard

                                  1 Antwort Letzte Antwort
                                  0
                                  • DutchmanD Offline
                                    DutchmanD Offline
                                    Dutchman
                                    Developer Most Active Administrators
                                    schrieb am zuletzt editiert von
                                    #310

                                    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 Antwort Letzte Antwort
                                    0
                                    • F Offline
                                      F Offline
                                      FriMatze
                                      schrieb am zuletzt editiert von
                                      #311

                                      @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 Antwort Letzte Antwort
                                      0
                                      • D Offline
                                        D Offline
                                        Dice19
                                        schrieb am zuletzt editiert von
                                        #312

                                        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 Antwort Letzte Antwort
                                        0
                                        • DutchmanD Offline
                                          DutchmanD Offline
                                          Dutchman
                                          Developer Most Active Administrators
                                          schrieb am zuletzt editiert von
                                          #313

                                          Hast du den in den datenobjecten Ruben kostpreis hinterlegt ?

                                          Sent from my iPhone using Tapatalk

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          544

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe