Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • 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. [gelöst] Datenpunt aus JSON String erstellen und verarbeiten

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    6
    1
    215

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    8
    1
    215

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    890

[gelöst] Datenpunt aus JSON String erstellen und verarbeiten

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
javascriptblocklycommunication
33 Beiträge 5 Kommentatoren 4.4k Aufrufe 4 Beobachtet
  • Ä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.
  • G guergen

    @paul53 Wie übergebe ich denn als Datenpunkt den Tag?
    Anstatt des Test1 soll das Datum stehen...

    schedule("0 23 * * *", function () {
      createState("PV.Test1", getState("0_userdata.0.PV.Max").val, JSON.parse('{"type":"number","unit":"W"}'), function () {
      });
    });
    
    paul53P Offline
    paul53P Offline
    paul53
    schrieb am zuletzt editiert von paul53
    #23

    @guergen sagte:

    Anstatt des Test1 soll das Datum stehen

    schedule("0 23 * * *", function () {
      let datum = formatDate(new Date(), 'YYYY.O.D');
      createState("PV." + datum, getState("0_userdata.0.PV.Max").val, {type: "number", unit: "W"});
    });
    

    Die Punkte im Datum erzeugen jedes Jahr und jeden Monat einen Ordner im Tab "Objekte". Wenn das nicht gewünscht ist, ersetze die Punkte durch Bindestriche. Doku. Datum heute bei der angegebenen Formatierung:

    2020.Mai.7
    

    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

    G 1 Antwort Letzte Antwort
    0
    • paul53P paul53

      @guergen sagte:

      Anstatt des Test1 soll das Datum stehen

      schedule("0 23 * * *", function () {
        let datum = formatDate(new Date(), 'YYYY.O.D');
        createState("PV." + datum, getState("0_userdata.0.PV.Max").val, {type: "number", unit: "W"});
      });
      

      Die Punkte im Datum erzeugen jedes Jahr und jeden Monat einen Ordner im Tab "Objekte". Wenn das nicht gewünscht ist, ersetze die Punkte durch Bindestriche. Doku. Datum heute bei der angegebenen Formatierung:

      2020.Mai.7
      
      G Online
      G Online
      guergen
      schrieb am zuletzt editiert von
      #24

      @paul53 OK, verstanden...!
      DP wird auch schon angelegt. jetzt muss ich nur noch den alten DP löschen, aber das bekomme ich hin!
      Danke!

      paul53P 1 Antwort Letzte Antwort
      0
      • G guergen

        @paul53 OK, verstanden...!
        DP wird auch schon angelegt. jetzt muss ich nur noch den alten DP löschen, aber das bekomme ich hin!
        Danke!

        paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von
        #25

        @guergen sagte:

        DP wird auch schon angelegt.

        Ist denn schon 23:00 Uhr ?
        Wenn die Sortier-Reihenfolge im Tab "Objekte" stimmen soll, dann verwende das Format "YYYY.MM.DD".

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

        G 2 Antworten Letzte Antwort
        0
        • paul53P paul53

          @guergen sagte:

          DP wird auch schon angelegt.

          Ist denn schon 23:00 Uhr ?
          Wenn die Sortier-Reihenfolge im Tab "Objekte" stimmen soll, dann verwende das Format "YYYY.MM.DD".

          G Online
          G Online
          guergen
          schrieb am zuletzt editiert von
          #26

          @paul53 Na ich kann doch schonmal mit einer anderen Uhrzeit testen...
          Habe es eben in YYYY.MM.DD geändert

          1 Antwort Letzte Antwort
          0
          • paul53P paul53

            @guergen sagte:

            DP wird auch schon angelegt.

            Ist denn schon 23:00 Uhr ?
            Wenn die Sortier-Reihenfolge im Tab "Objekte" stimmen soll, dann verwende das Format "YYYY.MM.DD".

            G Online
            G Online
            guergen
            schrieb am zuletzt editiert von guergen
            #27

            @paul53 Hmmmh... der soll den Max-Wert danach auf 0 setzen, habe ein Delay benutzt... geht nicht:

            schedule("27 19 * * *", function () {
            
              let datum = formatDate(new Date(), 'YYYY.MM.DD');
            
              createState("PV-Max." + datum, getState("0_userdata.0.PV.Max").val, {type: "number", unit: "W"});
                setStateDelayed("0_userdata.0.PV.Max", 0, 30000);
            });
            

            Ich befürchte, ich habe das mit den geschweiften Klammern noch nicht verstanden
            Es schreibt den blöden Wert nicht in den neuen DP

            1 Antwort Letzte Antwort
            0
            • G Online
              G Online
              guergen
              schrieb am zuletzt editiert von guergen
              #28

              OK, wenn der neue DP PV-Max heisst geht es nicht, lasse ich das-Max weg, geht es!

              paul53P 1 Antwort Letzte Antwort
              0
              • G guergen

                OK, wenn der neue DP PV-Max heisst geht es nicht, lasse ich das-Max weg, geht es!

                paul53P Offline
                paul53P Offline
                paul53
                schrieb am zuletzt editiert von
                #29

                @guergen sagte:

                wenn der neue DP PV-Max heisst geht es nicht

                Kann ich nicht nachvollziehen.

                CreateState_PV-Max.JPG

                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                1 Antwort Letzte Antwort
                0
                • paul53P paul53

                  @pmunz

                  on(idJson, function(dp) {
                      let obj = JSON.parse(dp.state.val);
                      if(obj.idx == 788) {
                          let arr = obj.svalue.split(';');
                          setState(idWert1 , parseFloat(arr[0]), true);
                          setState(idWert2 , parseFloat(arr[1]), true);
                          setState(idWert3 , parseFloat(arr[2]), true);
                      }
                  });
                  
                  P Offline
                  P Offline
                  pmunz
                  schrieb am zuletzt editiert von pmunz
                  #30

                  @paul53 sagte in Datenpunt aus JSON String erstellen und weiter verarbeiten:

                  @pmunz

                  on(idJson, function(dp) {
                      let obj = JSON.parse(dp.state.val);
                      if(obj.idx == 788) {
                          let arr = obj.svalue.split(';');
                          setState(idWert1 , parseFloat(arr[0]), true);
                          setState(idWert2 , parseFloat(arr[1]), true);
                          setState(idWert3 , parseFloat(arr[2]), true);
                      }
                  });
                  

                  @paul53
                  Wie kann ich den in diesem fall dazugehörige Datenpunkte erzeugen ?

                  const idVorraum_BWM1 = "mqtt.0.Vorraum_BWM1.in"; // {"idx":788,"RSSI":8,"nvalue":0,"svalue":"22.9;16.5;2"}
                  
                  const path = 'javascript.' + instance + '.SENSORBWM1.';
                  
                  const idsvalue = path + 'Temp';
                   
                  
                  if(!existsState(idsvalue)) { // Datenpunkte erzeugen
                  
                      createState(idsvalue, 'leer', {type: 'string'});
                  
                  };
                  
                   on(idVorraum_BWM1, function(dp) {
                  
                      let obj = JSON.parse(dp.state.val);
                  
                      if(obj.idx == 788) {
                  
                          let arr = obj.svalue.split(';');
                  
                          setState(idTemp , parseFloat(arr[0]), true);
                  
                          setState(idHum , parseFloat(arr[1]), true);
                          
                          }
                  
                  });
                  
                  paul53P 1 Antwort Letzte Antwort
                  0
                  • P pmunz

                    @paul53 sagte in Datenpunt aus JSON String erstellen und weiter verarbeiten:

                    @pmunz

                    on(idJson, function(dp) {
                        let obj = JSON.parse(dp.state.val);
                        if(obj.idx == 788) {
                            let arr = obj.svalue.split(';');
                            setState(idWert1 , parseFloat(arr[0]), true);
                            setState(idWert2 , parseFloat(arr[1]), true);
                            setState(idWert3 , parseFloat(arr[2]), true);
                        }
                    });
                    

                    @paul53
                    Wie kann ich den in diesem fall dazugehörige Datenpunkte erzeugen ?

                    const idVorraum_BWM1 = "mqtt.0.Vorraum_BWM1.in"; // {"idx":788,"RSSI":8,"nvalue":0,"svalue":"22.9;16.5;2"}
                    
                    const path = 'javascript.' + instance + '.SENSORBWM1.';
                    
                    const idsvalue = path + 'Temp';
                     
                    
                    if(!existsState(idsvalue)) { // Datenpunkte erzeugen
                    
                        createState(idsvalue, 'leer', {type: 'string'});
                    
                    };
                    
                     on(idVorraum_BWM1, function(dp) {
                    
                        let obj = JSON.parse(dp.state.val);
                    
                        if(obj.idx == 788) {
                    
                            let arr = obj.svalue.split(';');
                    
                            setState(idTemp , parseFloat(arr[0]), true);
                    
                            setState(idHum , parseFloat(arr[1]), true);
                            
                            }
                    
                    });
                    
                    paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von paul53
                    #31

                    @pmunz sagte in Datenpunt aus JSON String erstellen und weiter verarbeiten:

                    const idsvalue = path + 'Temp'; if(!existsState(idsvalue)) { // Datenpunkte erzeugen createState(idsvalue, 'leer', {type: 'string'}); };

                    Es müssen die gleichen Bezeichner verwendet werden wie bei setState().

                    const idTemp = path + 'Temperatur';
                    const idHum = path + 'Luftfeuchte';
                     
                    if(!existsState(idTemp)) { // Datenpunkte erzeugen
                        createState(idTemp, 0, {type: 'number', unit: '°C'});
                        createState(idHum, 0, {type: 'number', unit: '%'});
                    };
                    

                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                    P 1 Antwort Letzte Antwort
                    1
                    • paul53P paul53

                      @pmunz sagte in Datenpunt aus JSON String erstellen und weiter verarbeiten:

                      const idsvalue = path + 'Temp'; if(!existsState(idsvalue)) { // Datenpunkte erzeugen createState(idsvalue, 'leer', {type: 'string'}); };

                      Es müssen die gleichen Bezeichner verwendet werden wie bei setState().

                      const idTemp = path + 'Temperatur';
                      const idHum = path + 'Luftfeuchte';
                       
                      if(!existsState(idTemp)) { // Datenpunkte erzeugen
                          createState(idTemp, 0, {type: 'number', unit: '°C'});
                          createState(idHum, 0, {type: 'number', unit: '%'});
                      };
                      
                      P Offline
                      P Offline
                      pmunz
                      schrieb am zuletzt editiert von
                      #32

                      @paul53
                      Alles bestens es Funktioniert !
                      Danke

                      paul53P 1 Antwort Letzte Antwort
                      0
                      • P pmunz

                        @paul53
                        Alles bestens es Funktioniert !
                        Danke

                        paul53P Offline
                        paul53P Offline
                        paul53
                        schrieb am zuletzt editiert von
                        #33

                        @pmunz sagte:

                        es Funktioniert

                        Dann markiere bitte das Thema in der Überschrift des ersten Beitrags als [gelöst].

                        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                        1 Antwort Letzte Antwort
                        1

                        Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

                        Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

                        Mit deinem Input könnte dieser Beitrag noch besser werden 💗

                        Registrieren Anmelden
                        Antworten
                        • In einem neuen Thema antworten
                        Anmelden zum Antworten
                        • Älteste zuerst
                        • Neuste zuerst
                        • Meiste Stimmen


                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        486

                        Online

                        32.8k

                        Benutzer

                        82.8k

                        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