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.
    • 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
                      • Lenny.CB
                        Lenny.CB Most Active last edited by

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

                          Hm … mach mal

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

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

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

                              Schreib null mal klein. Mist

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

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

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

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

                                    @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 Reply Last reply Reply Quote 0
                                    • First post
                                      Last post

                                    Support us

                                    ioBroker
                                    Community Adapters
                                    Donate

                                    820
                                    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