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.4k

  • 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 116.9k 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.
  • 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 Online
                              L Online
                              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
                                      • D Offline
                                        D Offline
                                        Dice19
                                        schrieb am zuletzt editiert von
                                        #314

                                        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 Antwort Letzte Antwort
                                        0
                                        • sigi234S Online
                                          sigi234S Online
                                          sigi234
                                          Forum Testing Most Active
                                          schrieb am zuletzt editiert von
                                          #315

                                          Preis mit PUNKT eingeben!

                                          2858_screenshot__1202__li.jpg

                                          Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                                          Immer Daten sichern!

                                          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

                                          839

                                          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