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

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

[Vorlage] Stromverbrauch protokollieren - (etwas optimiert)

Geplant Angeheftet Gesperrt Verschoben JavaScript
455 Beiträge 81 Kommentatoren 116.8k 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.
  • 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
                    • SmarthomeMFS Offline
                      SmarthomeMFS Offline
                      SmarthomeMF
                      schrieb am zuletzt editiert von
                      #316

                      Hallo

                      Hört sich sehr interessant an.

                      Werde ich auch mal ausprobieren

                      Max

                      ioBroker auf einem NUC ,16GB RAM, 120GB SSD) mit Proxmox
                      Cloud Pro, iot, Alexa, Sonos, sonoff, Fronius, Harmony, Doorbird, Shelly, Hue, Loxone, Mihome, …

                      1 Antwort Letzte Antwort
                      0
                      • D Offline
                        D Offline
                        Dice19
                        schrieb am zuletzt editiert von
                        #317

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

                        1 Antwort Letzte Antwort
                        0
                        • cvidalC Offline
                          cvidalC Offline
                          cvidal
                          Forum Testing
                          schrieb am zuletzt editiert von
                          #318

                          @tobih83:

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

                          Den Post von sigi234 zwei weiter oben habt du gesehen?

                          Gruß Christian

                          1 Antwort Letzte Antwort
                          0
                          • D Offline
                            D Offline
                            Dice19
                            schrieb am zuletzt editiert von
                            #319

                            Ja….

                            2120_fehler_stromskript2.jpg

                            1 Antwort Letzte Antwort
                            0
                            • sigi234S Online
                              sigi234S Online
                              sigi234
                              Forum Testing Most Active
                              schrieb am zuletzt editiert von
                              #320

                              NICHT im Script eintragen sondern unter OBJEKTE! (javascript.0. - Verbrauchszaehler - Preis - Aktuell = 0.27 darunter Grundpreis= 8.0 ) oder wie dein Grundpreis eben ist.

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

                              1 Antwort Letzte Antwort
                              0
                              • Homer.J.H Offline
                                Homer.J.H Offline
                                Homer.J.
                                schrieb am zuletzt editiert von
                                #321

                                Hallo Gemeinde,

                                hab mal wieder eine Frage wie oder wo muss ich in dem Script was einfügen, ich bekomme meine Daten über einen Pulscounter ich habe auch alles schon in Watt und kW mit einem Script umgerechnet.

                                bekomme aber keine Daten geliefert.

                                Grüße
                                5373_screenshot_2018-11-24_objects_-_iobroker.png

                                1 Antwort Letzte Antwort
                                0
                                • WebrangerW Offline
                                  WebrangerW Offline
                                  Webranger
                                  schrieb am zuletzt editiert von
                                  #322

                                  321 Beiträge! Puh viel zu lesen.

                                  Ein Adapter ist noch nicht geplant für das Script oder?

                                  Gruss

                                  Intel NUC Celeron, Xiaomi Gateway, Fritzbox 7590, XS1

                                  1 Antwort Letzte Antwort
                                  0
                                  • Q Offline
                                    Q Offline
                                    quinti
                                    schrieb am zuletzt editiert von
                                    #323

                                    Hallo,

                                    erstmal danke für das tolle script!!!

                                    Läuft bei mir vorzüglich bis auf ein kleines Problem.

                                    Habe als history Adapter nun zu sql gewechselt.

                                    Seit dem gibts bei mir im log folgende Fehlermeldungen:

                                    2018-12-06 17:23:25.771 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=91 AND ts < 1512577380763;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
                                    2018-12-06 17:23:25.771 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=89 AND ts < 1512577380763;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
                                    2018-12-06 17:23:25.772 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=81 AND ts < 1512577380764;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
                                    2018-12-06 17:23:25.772 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=90 AND ts < 1512577380764;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
                                    2018-12-06 17:23:25.772 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=84 AND ts < 1512577380764;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
                                    2018-12-06 17:23:25.773 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=88 AND ts < 1512577380765;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
                                    2018-12-06 17:23:25.773 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=92 AND ts < 1512577380765;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
                                    2018-12-06 17:23:25.773 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=93 AND ts < 1512577380763;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
                                    2018-12-06 17:23:25.775 - error: sql.0 Cannot delete DELETE FROM `iobroker`.undefined WHERE id=87 AND ts < 1512577380769;: Error: ER_NO_SUCH_TABLE: Table 'iobroker.undefined' doesn't exist
                                    

                                    Wie bekomme ich die raus?

                                    1 Antwort Letzte Antwort
                                    0
                                    • WebrangerW Offline
                                      WebrangerW Offline
                                      Webranger
                                      schrieb am zuletzt editiert von
                                      #324

                                      Welchen Wert von meinem Discovergy Zähler muss ich eintragen das das Script ordentlich zählt und Rechnet?

                                      2958_bildschirmfoto_2018-12-06_um_18.17.39.png

                                      Den Aktuellen Verbrauch oder den Zählerstand?

                                      Gruß Danyel

                                      Intel NUC Celeron, Xiaomi Gateway, Fritzbox 7590, XS1

                                      1 Antwort Letzte Antwort
                                      0
                                      • jedoJ Offline
                                        jedoJ Offline
                                        jedo
                                        schrieb am zuletzt editiert von
                                        #325

                                        @ringdingringding:

                                        Den Aktuellen Verbrauch oder den Zählerstand? `

                                        Zählerstand!

                                        Viele Grüße,

                                        Jens

                                        1 Antwort Letzte Antwort
                                        0
                                        • G Offline
                                          G Offline
                                          GeorgS
                                          schrieb am zuletzt editiert von
                                          #326

                                          Hallo versuche grade das Script zum laufen zu bekommen… Leider werden keine Daten gelogt :(

                                          Habe Sonoffs und im Einstellungsbreich habe ich diese so eingefügt:

                                          var eigeneDatenpunkte = [
                                          [ 'sonoff.0.ComputerGeorg.ENERGY_Today', 'Computer', 'kWh', 'kWh' ],
                                          [ 'sonoff.0.Kuehlschrank.ENERGY_Today', 'Kuehlschrank', 'kWh', 'kWh' ],
                                          [ 'sonoff.0.Spuehlmaschiene.ENERGY_Today', 'Spuehlmaschiene', 'kWh', 'kWh' ]
                                          ];
                                          

                                          Unter Objekte wurden auch alle drei Komponenten eingefügt aber es werden keine Daten aufgezeichnet…

                                          Habe ich was falsch gemacht, das Script sonst nicht geändert?

                                          Edit by eric2905 : Logs, usw. bitte immer in Code- und ggf. Spoiler-Tags setzen

                                          grüße
                                          Georg

                                          Intel NUC, MaxCul, Xiaomi Vacuum Cleaner, Philips Hue, Zigbee, FritzDECT,Shelly

                                          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

                                          309

                                          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