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.
  • 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
                          • Lenny.CBL Offline
                            Lenny.CBL Offline
                            Lenny.CB
                            Most Active
                            schrieb am zuletzt editiert von
                            #31

                            @apollon77:

                            Hm … mach mal

                            console.log(JSON.stringify(getState(...).val, NULL, 2); ` hatte beim Einfügen einen Fehler. Habe dann vor dem ";" noch eine ")" gesetzt

                            console.log(JSON.stringify(getState('ical.1.data.table').val, NULL, 2));
                            

                            Ergebnis:````
                            javascript.1 2018-05-24 17:28:02.652 error at ContextifyScript.Script.runInContext (vm.js:35:29)
                            javascript.1 2018-05-24 17:28:02.652 error at script.js.Skript1:15:63
                            javascript.1 2018-05-24 17:28:02.651 error ReferenceError: NULL is not defined
                            javascript.1 2018-05-24 17:28:02.651 error ^
                            javascript.1 2018-05-24 17:28:02.650 error console.log(JSON.stringify(getState('ical.1.data.table').val, NULL, 2));
                            javascript.1 2018-05-24 17:28:02.650 error script.js.Skript1: script.js.Skript1:15
                            javascript.1 2018-05-24 17:28:02.620 info Start javascript script.js.Skript1

                            Achso, "Skript1:15:63" kommt desswegen, weil ich die anderen "Versuche" immer auskommentiere.
                            1 Antwort Letzte Antwort
                            0
                            • apollon77A Offline
                              apollon77A Offline
                              apollon77
                              schrieb am zuletzt editiert von
                              #32

                              Schreib null mal klein. Mist

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

                                @apollon77:

                                Schreib null mal klein. Mist ` das schaut besser aus… (ich habe mal alles persönliche mit "xxxxx" ersetzt.

                                ! javascript.1 2018-05-25 07:54:09.016 info script.js.Skript1: registered 0 subscriptions and 0 schedules
                                ! javascript.1 2018-05-25 07:54:09.016 info ]
                                ! javascript.1 2018-05-25 07:54:09.016 info }
                                ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineC"
                                ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-31T15:10:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-31T14:40:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineC ical_6days",
                                ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",,
                                ! javascript.1 2018-05-25 07:54:09.016 info "date": "In 6 Tagen 16:40-17:10",
                                ! javascript.1 2018-05-25 07:54:09.016 info {
                                ! javascript.1 2018-05-25 07:54:09.016 info },
                                ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineC"
                                ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-29T16:00:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-29T15:30:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineC ical_4days",
                                ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",,
                                ! javascript.1 2018-05-25 07:54:09.016 info "date": "In 4 Tagen 17:30-18:00",
                                ! javascript.1 2018-05-25 07:54:09.016 info {
                                ! javascript.1 2018-05-25 07:54:09.016 info },
                                ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineS"
                                ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-28T15:00:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-28T12:00:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineS ical_3days",
                                ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",,
                                ! javascript.1 2018-05-25 07:54:09.016 info "date": "In 3 Tagen 14:00-17:00",
                                ! javascript.1 2018-05-25 07:54:09.016 info {
                                ! javascript.1 2018-05-25 07:54:09.016 info },
                                ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineS"
                                ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-28T07:00:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-28T06:00:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineS ical_3days",
                                ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",,
                                ! javascript.1 2018-05-25 07:54:09.016 info "date": "In 3 Tagen 08:00-09:00",
                                ! javascript.1 2018-05-25 07:54:09.016 info {
                                ! javascript.1 2018-05-25 07:54:09.016 info },
                                ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineS"
                                ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-25T12:00:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-23T06:00:00.000Z",
                                ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineS ical_today",
                                ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",
                                ! javascript.1 2018-05-25 07:54:09.016 info "date": "Noch 6 Stunden",
                                ! javascript.1 2018-05-25 07:54:09.016 info {
                                ! javascript.1 2018-05-25 07:54:09.016 info script.js.Skript1: [
                                ! javascript.1 2018-05-25 07:54:08.987 info Start javascript script.js.Skript1
                                ! javascript.1 2018-05-25 07:54:08.961 info Stop script script.js.Skript1

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

                                  Dann kannst du es direkt nutzen. Brauchst kein parse. In de log Ausgabe siehst du was so drin ist.

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

                                    @apollon77:

                                    Dann kannst du es direkt nutzen. Brauchst kein parse. In de log Ausgabe siehst du was so drin ist. ` Dank dir erst einmal… Mal schauen ob ich da was 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

                                    433

                                    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