Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Ical-Einträge teilen?

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Ical-Einträge teilen?

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      simpixo last edited by

      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 Reply Last reply Reply Quote 0
      • AlCalzone
        AlCalzone Developer last edited by

        @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 😉

        1 Reply Last reply Reply Quote 0
        • Lenny.CB
          Lenny.CB Most Active last edited by

          @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 Reply Last reply Reply Quote 0
          • AlCalzone
            AlCalzone Developer last edited by

            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"?

            1 Reply Last reply Reply Quote 0
            • Lenny.CB
              Lenny.CB Most Active last edited by

              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 Reply Last reply Reply Quote 0
              • AlCalzone
                AlCalzone Developer last edited by

                > 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 "";
                
                
                1 Reply Last reply Reply Quote 0
                • Lenny.CB
                  Lenny.CB Most Active last edited by

                  @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 Reply Last reply Reply Quote 0
                  • S
                    simpixo last edited by

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

                    Gruß

                    Adrian

                    Gesendet von iPhone mit Tapatalk Pro

                    1 Reply Last reply Reply Quote 0
                    • S
                      simpixo last edited by

                      @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 Reply Last reply Reply Quote 0
                      • AlCalzone
                        AlCalzone Developer last edited by

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

                        1 Reply Last reply Reply Quote 0
                        • AlCalzone
                          AlCalzone Developer last edited by

                          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
                          
                          
                          1 Reply Last reply Reply Quote 0
                          • Lenny.CB
                            Lenny.CB Most Active last edited by

                            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 Reply Last reply Reply Quote 0
                            • Lenny.CB
                              Lenny.CB Most Active last edited by

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

                              1 Reply Last reply Reply Quote 0
                              • apollon77
                                apollon77 last edited by

                                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 😉

                                1 Reply Last reply Reply Quote 0
                                • Lenny.CB
                                  Lenny.CB Most Active last edited by

                                  @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 Reply Last reply Reply Quote 0
                                  • apollon77
                                    apollon77 last edited by

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

                                    1 Reply Last reply Reply Quote 0
                                    • Lenny.CB
                                      Lenny.CB Most Active last edited by

                                      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 Reply Last reply Reply Quote 0
                                      • apollon77
                                        apollon77 last edited by

                                        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

                                        1 Reply Last reply Reply Quote 0
                                        • Lenny.CB
                                          Lenny.CB Most Active last edited by

                                          @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 Reply Last reply Reply Quote 0
                                          • apollon77
                                            apollon77 last edited by

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

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            823
                                            Online

                                            31.9k
                                            Users

                                            80.2k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            35
                                            3591
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo