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. Datenpunkte in json zusammenfassen

NEWS

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

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

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

Datenpunkte in json zusammenfassen

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
3 Beiträge 2 Kommentatoren 1.2k Aufrufe
  • Ä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.
  • T Offline
    T Offline
    Torsten_MG
    schrieb am zuletzt editiert von
    #1

    Hallo,

    ich habe mit ein bisschen Unterstützung einiger Leute es hinbekommen, dass ich für meinen Abfahrtmonitor (Bus) alle relevanten Daten in Datenpunkte ablegen konnte.

    Hier mal der Code, den ich jetzt verwende:

    schedule('* * * * *', datenlesen); // jede minute
    var request = require('request');
    var logging = true;
    
    createState('Verkehr.Aktualisieren', false, {
            desc: 'Werte aktualisieren',
            type: 'boolean',
            def:  false,
            role: 'indicator'    
    });
    for(let i = 0; i < 4; i++) {
    	createState('Verkehr.Richtung_xx.Startzeit'+i, 0, {
    		});
    	createState('Verkehr.Richtung_xx.Verspaetung'+i, 0, {
    		});	
    	createState('Verkehr.Richtung_xx.Haltestelle'+i, 0, {
    		});
    	createState('Verkehr.Richtung_xx.Linie'+i, 0, {
    		});
    	createState('Verkehr.Richtung_xx.tats_zeit'+i, 0, {
    		});
    		}
    function datenlesen() {
        //Zuhause nach Zentrum
        var link = 'https://vrrf.finalrewind.org/xxx/xxx.json?frontend=json&offset=1&platform=1' ;
        log('Verkehr Daten einlesen');
        request(link, function (error, response, body) {
            if (!error && response.statusCode == 200) {
                var result;
                try{
                    result = JSON.parse(body);
    
                    if (logging) log('Kein Fehler beim Einlesen Verkehr Daten');
    
                } catch (e) {
                    log('Parse Fehler (Roofi Modul):' + e);
                }    
                if (result) {
    
                    var Startzeit;
                    var Verspaetung;
                    var Haltestelle;
                    var Linie;
                    var TatsZeit;
    
    			for(let j = 0; j < 4; j++) {
    				//Startzeit
                    if (logging) log(result.raw[j].sched_time);
    				//Verspaetung
                    if (logging) log(result.raw[j].delay);
    				//Ziel Haltestelle
                    if (logging) log(result.raw[j].destination);
    				//Linie
                    if (logging) log(result.raw[j].line);
    				//Tatsächliche Zeit
                    if (logging) log(result.raw[j].time);
    
                    Startzeit = result.raw[j].sched_time;
                    Verspaetung = result.raw[j].delay;
                    Haltestelle = result.raw[j].destination;
                    Linie = result.raw[j].line;
                    TatsZeit = result.raw[j].time;
    
                    setState("javascript.0.Verkehr.Richtung_xx.Startzeit"+j,Startzeit);
                    setState("javascript.0.Verkehr.Richtung_xx.Verspaetung"+j,Verspaetung);
                    setState("javascript.0.Verkehr.Richtung_xx.Haltestelle"+j,Haltestelle);
                    setState("javascript.0.Verkehr.Richtung_xx.Linie"+j,Linie);
                    setState("javascript.0.Verkehr.Richtung_xx.tats_zeit"+j,TatsZeit);
                }    
    
                    setState("javascript.0.Verkehr.Aktualisieren", false);
                    setState("javascript.0.VIS.Overlay", 5);
                //    setState("javascript.0.VIS.Overlay_iPhoneX", 5);
                }
            } else log('Fehler (Verkehr Daten Abfrage: ' + error);
        });   // Ende request 
        log('Verkehr Daten eingelesen');
    }
    datenlesen ();
    

    Jetzt hätte ich aber gerne, dass diese Daten wieder in eine JSON zusammengefasst werden für meine Tabelle in vis. Wie kann ich das Umsetzen?

    1 Antwort Letzte Antwort
    0
    • foxriver76F Offline
      foxriver76F Offline
      foxriver76
      Developer
      schrieb am zuletzt editiert von
      #2

      Geht es dir allgemein darum, wie du ein JSON aus Datenpunkten erstellen kannst. Grundsätzlich ist JSON ziemlich tief verankert in JS, wie es der Name ja vermuten lässt.

      Du kannst einfach ein JSON Objekt initialisieren

      let meinJSONObjekt = {}; // alternativ = new Object();
      
      

      und dieses Objekt erweitern

      meinJSONObjekt.zahl = 1; 
      meinJSOnObjekt.zeichenkette = 'test';
      
      

      wenn du dir das dann in lesbarer Form ausgeben möchtest:

      console.log(JSON.stringify(meinJSONObjekt));
      
      

      die Ausgabe wird in etwa so aussehen:

      {
      	"zahl": 1,
      	"zeichenkette": "test"
      }
      
      

      beste Grüße

      fox

      Videotutorials & mehr

      Hier könnt ihr mich unterstützen.

      1 Antwort Letzte Antwort
      0
      • T Offline
        T Offline
        Torsten_MG
        schrieb am zuletzt editiert von
        #3

        danke, werde ich mir später mal anschauen ob ich das hinbekomme!

        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

        437

        Online

        32.4k

        Benutzer

        81.5k

        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