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
    #2

    keiner ne Idee? :shock:

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

      Das sollte in Javascript mit einem regulären Ausdruck machbar sein. Jedoch ist mir nicht ganz klar, welchen Output du erwartest. Wenn du mir eine kleine Aufstellung gibst, wie die Daten transformiert werden sollen, könnte ich evtl aushelfen.

      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
        #4

        @AlCalzone:

        …Wenn du mir eine kleine Aufstellung gibst, wie die Daten transformiert werden sollen, könnte ich evtl aushelfen. `

        ich versuche es…

        in einer Instanz habe ich drei Kalender (Frau, Tochter, meinen). Diese drei sind farblich getrennt. In einer Übersicht auf einem TAB sind die Termine aus der ical-Instanz (3 Kalender) aufgelistet.

        Nun wollte ich mit Klick auf die Übersicht in eine View springen und die Termine Separieren/Sortieren oder wie man es nennen mag.

        Quasi 983_ical.jpg

        1 Antwort Letzte Antwort
        0
        • A Offline
          A Offline
          andyb
          schrieb am zuletzt editiert von
          #5

          Für jeden der kalender eine separate ical Instanz wäre die einfachste Lösung

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

            @andyb:

            Für jeden der kalender eine separate ical Instanz wäre die einfachste Lösung `
            richtig. wollte ich aber nicht. Außerdem brauche ich dann 4 Instanzen. Eine mit allen 3 Kalendern und noch 3 Instanzen mit jeweils einem Kalender.

            Das ist m.E. nicht zielführend.

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

              Ich glaube, du hast nicht ganz verstanden, was ich von dir wollte. Aber egal, wollen wir mal…

              Dieser Code liest den state aus und sucht alle Termine raus

              var html = getState("ical.1.data.html").val;
              
              var regex = /^.+ical[a-zA-Z]+.\>([^\<]+).+color:(#[0-9a-zA-Z]+).+ical[a-zA-Z0-9]+.\>([^\<]+).+$/gm
              
              // Alle Termine finden
              var results = [];
              var match;
              // und Details auslesen
              while (match = regex.exec(html)) {
                  results.push({
                      farbe: match[2],
                      datum: match[1],
                      name: match[3]
                  });
              }
              
              

              Der reguläre Ausdurck (regex) nimmt relativ viel über den Aufbau des html-Codes an. Sollte der sich mal grundlegend ändern, muss hier nachgebessert werden. Am Ende steht in der results-Variable ein Objekt für jeden Termin:

              [
                  { "farbe": "#FF0AFF", "datum": "Morgen 08:00-09:00", "name": " Test 1" },
                  { "farbe": "#00BFFF", "datum": "Übermorgen 08:00-09:00", "name": " test 2" },
                  { "farbe": "#00FF00", "datum": "In 3 Tagen 16:15-17:45", "name": " Test 3" },
                  { "farbe": "#00FF00", "datum": "In 5 Tagen 16:15-17:45", "name": " Test 4" }
              ]
              
              

              Jetzt geht es daran, das ganze zu gruppieren. Hierfür ist die eingebaute reduce-Funktion sehr hilfreich:

              // Termine nach Farbe gruppieren
              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,
                      datum: termin.datum
                  });
              
                  // Sammlerobjekt zurückgeben für den nächsten Aufruf
                  return gruppiert;
              }, {});
              
              

              Sie bekommt ein leeres Sammler-Objekt {} übergeben, wendet die Funktion auf jedes Element des Arrays an und übergibt dieser jeweils das aktuelle Sammler-Objekt.

              Die Funktion prüft, ob bereits ein Kalender-Array dieser Farbe angelegt ist und erstellt es, wenn nötig. Dann wird der Termin dort eingetragen.

              Am Ende hast du folgendes Objekt in der kalender-Variable:

              /*var kalender =*/ {
                  "#FF0AFF": [{ "datum": "Morgen 08:00-09:00", "name": " Test 1" }],
                  "#00BFFF": [{ "datum": "Übermorgen 08:00-09:00", "name": " test 2" }],
                  "#00FF00": [{ "datum": "In 3 Tagen 16:15-17:45", "name": " Test 3" }, { "datum": "In 5 Tagen 16:15-17:45", "name": " Test 4" }]
              };
              
              

              auf alle Termine eines Kalenders kannst du nun z.B. zugreifen mit

              kalender["#FF0AFF"]
              
              

              Die Frage ist jetzt: Kannst du mit dieser Form der Daten was anfangen? Oder brauchst du sie irgendwie anders?

              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
                #8

                das schaut doch schon mal richtig gut aus.

                vielen Dank dafür!

                Mein script sieht nun so aus:

                var instanz =   'javascript.' + instance + '.';
                var pfad =      'Kalender'; 
                var html =      getState("ical.1.data.html").val;
                var regex =     /^.+ical[a-zA-Z]+.\>([^\<]+).+color:(#[0-9a-zA-Z]+).+ical[a-zA-Z0-9]+.\>([^\<]+).+$/gm
                
                createState(instanz + pfad + '.K1');
                createState(instanz + pfad + '.K2');
                createState(instanz + pfad + '.K3');
                
                // Alle Termine finden
                var results = [];
                var match;
                // und Details auslesen
                while (match = regex.exec(html)) {
                    results.push({
                        farbe: match[2],
                        datum: match[1],
                        name: match[3]
                    });
                }
                
                // Termine nach Farbe gruppieren
                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,
                        datum: termin.datum
                    });
                
                    // Sammlerobjekt zurückgeben für den nächsten Aufruf
                    return gruppiert;
                
                }, {});
                
                setState(instanz + pfad + '.K1',JSON.stringify(kalender["#00FF00"]));
                setState(instanz + pfad + '.K2',JSON.stringify(kalender["#FF0AFF"]));
                setState(instanz + pfad + '.K3',JSON.stringify(kalender["#00BFFF"]));
                

                Und so schaut dann das Ergebnis aus: 983_ical.jpg Muss jetzt bloß nochmal schauen ob und wie er mir das als HTML-Tabelle speichert. Die JSON-Tabelle find ich nicht so schön.

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

                  Gerade getestet und es ist der Hammer!!! [emoji1360]

                  Das baue ich dann auch noch bei mir ein [emoji6]

                  Gruß

                  Adrian

                  Gesendet von iPhone mit Tapatalk Pro

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

                    @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 ;)

                    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
                      #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
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          583

                                          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