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. Ical-Einträge teilen?

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.2k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

Ical-Einträge teilen?

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
35 Beiträge 5 Kommentatoren 3.7k 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.
  • Lenny.CBL Offline
    Lenny.CBL Offline
    Lenny.CB
    Most Active
    schrieb am zuletzt editiert von
    #11

    @AlCalzone:

    @Lenny.CB:

    Muss jetzt bloß nochmal schauen ob und wie er mir das als HTML-Tabelle speichert. Die JSON-Tabelle find ich nicht so schön. Gibt mir ein Beispiel für ne HTML-Tabelle mit 2-3 Zeilen und ich liefer dir das Skript dazu ;)

    ist quasi wie im ersten Post. Das habe ich aus dem Objekt ical.1.data.html rauskopiert

    hier nochmal aktuell:

    Morgen 08:00-09:00 test K3
    
    Morgen 08:00-09:00 Test K2
    
    Morgen 09:45-11:45 test K1
    
    In 6 Tagen 09:00-12:00 test K1
    

    wobei hier 2x "Farbe" vorkommt.

    Die Kalenderfarbe brauch ich da nicht unbedingt, aber die unterschiedlichen "PreWarn"-Farben wären cool.

    1 Antwort Letzte Antwort
    0
    • AlCalzoneA Offline
      AlCalzoneA Offline
      AlCalzone
      Developer
      schrieb am zuletzt editiert von
      #12

      Ok, dann modifizieren wir das Ganze ein wenig. Ich beziehe mich hier auf deinen Code und gebe die jeweils neuen/geänderten Zeilen an

      var regex = /^.+(ical[a-zA-Z]+).\>([^\<]+).+color:(#[0-9a-zA-Z]+).+ical[a-zA-Z0-9]+.\>([^\<]+).+$/gm;
      

      -> Klammer um ersten Ausdruck (matcht die ical-Klasse)

      while (match = regex.exec(html)) {
          results.push({
              farbe: match[3],
              datum: match[2],
              name: match[4],
              stufe: match[1]
          });
      }
      
      

      -> Warnstufe ist jetzt die erste Match-Gruppe

      var kalender = results.reduce(function (gruppiert, termin) {
          // Kalender dieser Farbe intialisieren, wenn nicht schon geschehen
          if (!gruppiert[termin.farbe]) gruppiert[termin.farbe] = [];
      
          // Termin hinzufügen
          gruppiert[termin.farbe].push({
              name: termin.name,
              stufe: termin.stufe,
              datum: termin.datum
          });
      
          // Sammlerobjekt zurückgeben für den nächsten Aufruf
          return gruppiert;
      }, {});
      
      

      -> Stufe mit in Objekt aufnehmen

      Und jetzt neu:

      function toHtml(kalender) {
          return kalender.reduce(function(html, termin) {
              if (html != "") html += "
      \n";
              html += '' + termin.datum + '' + 
                  '' + termin.name + '';
              return html;
          }, "");
      }
      
      

      z.B. so aufrufen: toHtml(kalender["#00FF00"]);

      Habe den Html-Code um mmn. nicht benötigte s bereinigt und die zugehörigen End-Tags eingefügt (die haben gefehlt).

      Hab ich dich richtig verstanden, dass du die "icalNormal/icalWarn"-CSS-Klassen haben willst und nicht die Farben "orange/#FFFFFF"?

      Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

      1 Antwort Letzte Antwort
      0
      • Lenny.CBL Offline
        Lenny.CBL Offline
        Lenny.CB
        Most Active
        schrieb am zuletzt editiert von
        #13

        prima, funktioniert soweit gut.

        mir ist aufgefallen, wenn zu einem Kalender kein Termin vorhanden ist, gibt es eine Fehlermeldung:
        > javascript.2 script.js.readKalender_v2: TypeError: Cannot read property 'reduce' of undefined at toHtml (script.js.readKalender_v2:39:20) at script.js.readKalender_v2:52:36
        Zeile 39: return kalender.reduce(function(html, termin) {

        Zeile 52: setState(instanz + pfad + '.K3',toHtml(kalender["#00BFFF"]));

        Muss da noch etwas rein was prüft ob eine Termin vorhanden ist?

        1 Antwort Letzte Antwort
        0
        • AlCalzoneA Offline
          AlCalzoneA Offline
          AlCalzone
          Developer
          schrieb am zuletzt editiert von
          #14

          > wenn zu einem Kalender kein Termin vorhanden ist, gibt es eine Fehlermeldung
          Zu Beginn der toHtml-Funktion folgendes einfügen:

          if (! (kalender && kalender.length)) return "";
          
          

          Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

          1 Antwort Letzte Antwort
          0
          • Lenny.CBL Offline
            Lenny.CBL Offline
            Lenny.CB
            Most Active
            schrieb am zuletzt editiert von
            #15

            @AlCalzone:

            > wenn zu einem Kalender kein Termin vorhanden ist, gibt es eine Fehlermeldung
            Zu Beginn der toHtml-Funktion folgendes einfügen:

            if (! (kalender && kalender.length)) return "";
            
            ```` `  
            

            gemacht und läuft!

            besten Dank!

            1 Antwort Letzte Antwort
            0
            • S Offline
              S Offline
              simpixo
              schrieb am zuletzt editiert von
              #16

              Bei mir läuft es auch….. GEILOMAT! Super Script!!!

              Gruß

              Adrian

              Gesendet von iPhone mit Tapatalk Pro

              1 Antwort Letzte Antwort
              0
              • S Offline
                S Offline
                simpixo
                schrieb am zuletzt editiert von
                #17

                @AlCalzone:

                Ok, dann modifizieren wir das Ganze ein wenig. Ich beziehe mich hier auf deinen Code und gebe die jeweils neuen/geänderten Zeilen an

                var regex = /^.+(ical[a-zA-Z]+).\>([^\<]+).+color:(#[0-9a-zA-Z]+).+ical[a-zA-Z0-9]+.\>([^\<]+).+$/gm;
                

                -> Klammer um ersten Ausdruck (matcht die ical-Klasse)

                while (match = regex.exec(html)) {
                    results.push({
                        farbe: match[3],
                        datum: match[2],
                        name: match[4],
                        stufe: match[1]
                    });
                }
                
                

                -> Warnstufe ist jetzt die erste Match-Gruppe

                var kalender = results.reduce(function (gruppiert, termin) {
                    // Kalender dieser Farbe intialisieren, wenn nicht schon geschehen
                    if (!gruppiert[termin.farbe]) gruppiert[termin.farbe] = [];
                
                    // Termin hinzufügen
                    gruppiert[termin.farbe].push({
                        name: termin.name,
                        stufe: termin.stufe,
                        datum: termin.datum
                    });
                
                    // Sammlerobjekt zurückgeben für den nächsten Aufruf
                    return gruppiert;
                }, {});
                
                

                -> Stufe mit in Objekt aufnehmen

                Und jetzt neu:

                function toHtml(kalender) {
                    return kalender.reduce(function(html, termin) {
                        if (html != "") html += "
                \n";
                        html += '' + termin.datum + '' + 
                            '' + termin.name + '';
                        return html;
                    }, "");
                }
                
                

                z.B. so aufrufen: toHtml(kalender["#00FF00"]);

                Habe den Html-Code um mmn. nicht benötigte s bereinigt und die zugehörigen End-Tags eingefügt (die haben gefehlt).

                Hab ich dich richtig verstanden, dass du die "icalNormal/icalWarn"-CSS-Klassen haben willst und nicht die Farben "orange/#FFFFFF"? `

                Wäre es auch möglich die Farben die die Einträge vorher gehabt haben mit zu übernehmen? Also wenn der Kalender zB. rot war sind ja alle Einträge auch rot.

                Nachdem dein Script sie aufgeteilt hat sind die Farben weg. Oder übersehe ich was?

                Gruß

                Adrian

                1 Antwort Letzte Antwort
                0
                • AlCalzoneA Offline
                  AlCalzoneA Offline
                  AlCalzone
                  Developer
                  schrieb am zuletzt editiert von
                  #18

                  Das ist korrekt, dazu muss das Regex und die Auswertung der Matches angepasst werden. Komme ich heute nicht mehr dazu, ich melde mich morgen.

                  Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                  1 Antwort Letzte Antwort
                  0
                  • AlCalzoneA Offline
                    AlCalzoneA Offline
                    AlCalzone
                    Developer
                    schrieb am zuletzt editiert von
                    #19

                    Hier das vollständige Skript:

                    var html = ...;
                    
                    var regex = /^.+color:\s?([#0-9A-Za-z]+).+(ical[a-zA-Z]+).\>([^\<]+).+color:(#[0-9a-zA-Z]+).+ical[a-zA-Z0-9]+.\>\s?([^\<]+).+$/gm
                    
                    // Alle Termine finden
                    var results = [];
                    var match;
                    // und Details auslesen
                    while (match = regex.exec(html)) {
                        results.push({
                            farbe: match[1],
                            kalender: match[4],
                            datum: match[3],
                            name: match[5],
                            stufe: match[2]
                        });
                    }
                    
                    var kalender = {};
                    if (results.length)
                      kalender = results.reduce(function (gruppiert, termin) {
                          // Kalender dieser Farbe intialisieren, wenn nicht schon geschehen
                          if (!gruppiert[termin.kalender]) gruppiert[termin.kalender] = [];
                    
                          // Termin hinzufügen
                          gruppiert[termin.kalender].push({
                              name: termin.name,
                              stufe: termin.stufe,
                              datum: termin.datum,
                              farbe: termin.farbe
                          });
                    
                          // Sammlerobjekt zurückgeben für den nächsten Aufruf
                          return gruppiert;
                      }, {});
                    
                    function toHtml(kalender) {
                        if (! (kalender && kalender.length)) return "";
                        return kalender.reduce(function(html, termin) {
                            if (html != "") html += "
                    \n";
                            html += '' + termin.datum + '' + 
                                '' + termin.name + '';
                            return html;
                        }, "");
                    }
                    
                    

                    Beispielausgabe:

                    toHtml(kalender["#00FF00"]);
                    
                    liefert:
                    
                    In 3 Tagen 16:15-17:45Test 3
                    
                    In 5 Tagen 16:15-17:45Test 4
                    
                    

                    Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                    1 Antwort Letzte Antwort
                    0
                    • Lenny.CBL Offline
                      Lenny.CBL Offline
                      Lenny.CB
                      Most Active
                      schrieb am zuletzt editiert von
                      #20

                      Hallo zusammen,

                      eben festgestellt, dass das Script keine Ergebnisse mehr bringt.

                      Habe mal versucht mit den Daten von "ical.1.data.html" im online-regex-Tester zu spielen.

                      Dabei ist mir aufgefallen, dass der Zeilenumbruch fehlt. Setze ich nach dem
                      im Tester ein "Enter" werden auch wieder alle Einträge lt. Suche korrekt gefunden.

                      Wurde hier was in die Richtung am ical-Adapter geändert. Habe versucht das auf GIT nachzuvollziehen, sehe da aber leider mit den vielen Versionen nicht durch.

                      1 Antwort Letzte Antwort
                      0
                      • Lenny.CBL Offline
                        Lenny.CBL Offline
                        Lenny.CB
                        Most Active
                        schrieb am zuletzt editiert von
                        #21

                        @ Apollon77: kann das mit deinen Änderungen am Adapter zu tun haben?

                        1 Antwort Letzte Antwort
                        0
                        • apollon77A Offline
                          apollon77A Offline
                          apollon77
                          schrieb am zuletzt editiert von
                          #22

                          Das kann sehr gut sein. Das html war an einigen Stellen fehlerhaft und das wurde irgendwann gefixt.

                          Die Idee das html zu parsen ist auch nicht wirklich ideal ;-)

                          Jetzt exakt Forensik zu betreiben wann ich da was geändert habe was mit der regex kollidiert wäre mühsehlig ;-(

                          Option A: passt die regex an. Ich verspreche aber nicht das eine künftige Optimierung der html Darstellung bzw für vis das wieder ändert!

                          Option B: nehmt, wie sinnvoller, die Data.table als json Objekt als Grundlage für eine skriptuelle Verarbeitung ;-)

                          Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                          • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                          • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                          1 Antwort Letzte Antwort
                          0
                          • Lenny.CBL Offline
                            Lenny.CBL Offline
                            Lenny.CB
                            Most Active
                            schrieb am zuletzt editiert von
                            #23

                            @apollon77:

                            Option B: nehmt, wie sinnvoller, die Data.table als json Objekt als Grundlage für eine skriptuelle Verarbeitung ;-) `
                            Habe befürchtet das sowas kommt. Das war der Zauber mit JSON.stringify….. richtig?

                            Oder gibt es vielleicht schon was Fertiges? :-)

                            1 Antwort Letzte Antwort
                            0
                            • apollon77A Offline
                              apollon77A Offline
                              apollon77
                              schrieb am zuletzt editiert von
                              #24

                              In dem Fall

                              var data = JSON.parse(getState(„ical.0.data.table“).val);

                              Und dann hast du es schon.

                              Ausgabe strukturiert danach:

                              console.log(JSON.stringify(data,NULL,2));

                              Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                              • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                              • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                              1 Antwort Letzte Antwort
                              0
                              • Lenny.CBL Offline
                                Lenny.CBL Offline
                                Lenny.CB
                                Most Active
                                schrieb am zuletzt editiert von
                                #25

                                so hatte ich auch angefangen. Da kamen dann schon die Fehler…

                                blöderweise steige ich bei javascript immer noch nicht durch... :oops:

                                var data = JSON.parse(getState("ical.1.data.table").val);
                                console.log(JSON.stringify(data,NULL,2));
                                
                                javascript.1	2018-05-24 07:09:03.755	error	at ContextifyScript.Script.runInContext (vm.js:35:29)
                                javascript.1	2018-05-24 07:09:03.755	error	at script.js.Skript1:11:17
                                javascript.1	2018-05-24 07:09:03.754	error	at Object.parse (native)
                                javascript.1	2018-05-24 07:09:03.754	error	SyntaxError: Unexpected token o in JSON at position 1
                                javascript.1	2018-05-24 07:09:03.754	error	^
                                javascript.1	2018-05-24 07:09:03.754	error	[object Object],[object Object],[object Object],[object Object]
                                javascript.1	2018-05-24 07:09:03.753	error	script.js.Skript1: undefined:1
                                
                                1 Antwort Letzte Antwort
                                0
                                • apollon77A Offline
                                  apollon77A Offline
                                  apollon77
                                  schrieb am zuletzt editiert von
                                  #26

                                  Was ist denn in deinem Skript in Zeile 11?! Oder hast du globale Skripte noch? Scheinbar sieht das json komisch aus.

                                  Gib den Wert doch mal vor dem json. Parse aus

                                  Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                  • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                  • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                  1 Antwort Letzte Antwort
                                  0
                                  • Lenny.CBL Offline
                                    Lenny.CBL Offline
                                    Lenny.CB
                                    Most Active
                                    schrieb am zuletzt editiert von
                                    #27

                                    @apollon77:

                                    Was ist denn in deinem Skript in Zeile 11?! `
                                    Zeile 11 gibt es nicht. Das ursprüngliche Script ist gestoppt. Ich hatte in einem "Testscript" nur deine beiden Zeilen drin. Wollte mal im Log schauen was dabei rum kommt und mir mit "copy & paste" im "try a& error"-Modus was zusammen frickeln.

                                    var data = JSON.parse(getState("ical.1.data.table").val);
                                    console.log(JSON.stringify(data,NULL,2));
                                    

                                    @apollon77:

                                    Oder hast du globale Skripte noch? ` Nein, nichts unter common, nichts unter global.
                                    @apollon77:

                                    Scheinbar sieht das json komisch aus. ` Jupp, denke ich auch.
                                    @apollon77:

                                    Gib den Wert doch mal vor dem json. Parse aus ` Oh Gott ich hoffe du schlägst mich jetzt nicht… Wie mache ich das? :shock:

                                    1 Antwort Letzte Antwort
                                    0
                                    • apollon77A Offline
                                      apollon77A Offline
                                      apollon77
                                      schrieb am zuletzt editiert von
                                      #28

                                      console.log(getState(„ical.1.data.table“).val);

                                      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                      1 Antwort Letzte Antwort
                                      0
                                      • Lenny.CBL Offline
                                        Lenny.CBL Offline
                                        Lenny.CB
                                        Most Active
                                        schrieb am zuletzt editiert von
                                        #29

                                        @apollon77:

                                        console.log(getState(„ical.1.data.table“).val); ` kommt das bei rum…````
                                        javascript.1 2018-05-24 15:41:08.401 info script.js.Skript1: registered 0 subscriptions and 0 schedules
                                        javascript.1 2018-05-24 15:41:08.400 info script.js.Skript1: [object Object],[object Object],[object Object],[object Object]
                                        javascript.1 2018-05-24 15:41:08.391 info Start javascript script.js.Skript1
                                        javascript.1 2018-05-24 15:41:08.361 info Stop script script.js.Skript1

                                        1 Antwort Letzte Antwort
                                        0
                                        • apollon77A Offline
                                          apollon77A Offline
                                          apollon77
                                          schrieb am zuletzt editiert von
                                          #30

                                          Hm … mach mal

                                          console.log(JSON.stringify(getState(...).val, NULL, 2);

                                          Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                          • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                          • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                          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

                                          540

                                          Online

                                          32.7k

                                          Benutzer

                                          82.3k

                                          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