Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Kalender von Website auslesen

    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

    Kalender von Website auslesen

    This topic has been deleted. Only users with topic management privileges can see it.
    • D
      dirkhe Developer @liv-in-sky last edited by dirkhe

      @liv-in-sky aber wenn man die jetzt in den calender eintragen würde, müsste man noch sicherstellen, dass die nicht doppelt eingetragen werden. Das macht das ganze natürlich einiges schwieriger.... würde ich dann auch in der verantwortung des scriptes sehen.
      Die frage wäre dann, müssen die in den kalender eingetragen werde, oder nutzt man das als quelle für den adapter, also dass diese ereignisse quasi in die struktur des adapters eingetragen werden.

      liv-in-sky 1 Reply Last reply Reply Quote 0
      • D
        dirkhe Developer @liv-in-sky last edited by

        @liv-in-sky sagte in Kalender von Website auslesen:

        ich hasse diese google api anmeldung

        Ich auch, hatte das ja auf Anfrage eingebaut, ich selber nutze einen nextcloud adapter

        1 Reply Last reply Reply Quote 0
        • liv-in-sky
          liv-in-sky @dirkhe last edited by

          @dirkhe

          sollte eigentlich nur einmal pro woche laufen - ds kann man dann einfach überprüfen, ob man die aktuelle woche bekommen hat und nicht doppelt schreibt

          @dirkhe sagte in Kalender von Website auslesen:

          Die frage wäre dann, müssen die in den kalender eingetragen werde, oder nutzt man das als quelle für den adapter, also dass diese ereignisse quasi in die struktur des adapters eingetragen werden.

          bin mir nicht sicher, ob ich dich verstehe - ich weiß ja noch nicht, ob alle eingetragen werden sollen, oder ob was gefiltert wird - daher bräuchte das script eine art sendto zum adapter, welches eine evtl. json annimmt und an den kalender weiterleitet

          D 1 Reply Last reply Reply Quote 0
          • D
            dirkhe Developer @liv-in-sky last edited by

            @liv-in-sky das mit dem sento sollte nicht das problem sein und das man das als json übergibt, sollte auch klar sein.
            Die sendto schnittste habe ich eh schon drin, weil ich darüber die testfunktion abgebildet habe.
            Nur über die rückgabe, ggf. Incl. Fehler müsste ich mir was überlegen.

            liv-in-sky 1 Reply Last reply Reply Quote 0
            • liv-in-sky
              liv-in-sky @dirkhe last edited by

              @dirkhe

              ich werde mir morgen nochmal das mit der google api und deinem adapter ansehen - beim letzten mal habe ich frustriert aufgegeben

              ich sag dir dann bescheid, wie weit ich gekommen bin

              1 Reply Last reply Reply Quote 1
              • A
                andrenaether last edited by

                @liv-in-sky

                Mega ..... wow ich hätte nicht gedacht das man das aus der Website bekommt. wie ist es wenn man die Website mehrmals in der woch abfragt nach (Änderungen)
                würde man dann jedes mal alles doppelt schreiben ??

                Ps. Ich habe auch erst seid Kurzen den ical Adapter gefunden ( Weil viele das Problem Hatten mit anmelden und Co)

                Die Idee von mir ist halt zb. Am Sonntag oder Montag (Aktuelle Woche ) die Daten in den Kalender zu schreiben. ( Oder ist es sinnvoller die gesamten Daten einmal von januar bis Dezember zu schreiben und auf veränderungen Reagieren ..... 🤷‍♂️

                liv-in-sky 3 Replies Last reply Reply Quote 0
                • liv-in-sky
                  liv-in-sky @andrenaether last edited by liv-in-sky

                  @andrenaether sagte in Kalender von Website auslesen:

                  Die Idee von mir ist halt zb. Am Sonntag oder Montag (Aktuelle Woche ) die Daten in den Kalender zu schreiben. ( Oder ist es sinnvoller die gesamten Daten einmal von januar bis Dezember zu schreiben und auf veränderungen Reagieren

                  ne - jede woche einmal - ansonsten musst du immer zuerst im kalender nach den einträgen suchen . aber zuerst muss ich noch rausfinden, wie genau man in den g-cal shreibt

                  https://forum.iobroker.net/post/1027448

                  1 Reply Last reply Reply Quote 0
                  • liv-in-sky
                    liv-in-sky @andrenaether last edited by liv-in-sky

                    @andrenaether

                    hi - um das mal erreichen zu können, mussst du dir den webcal adapter installieren und dich bei deinem google calender anmelden - das könntest du schon mal vorbereiten

                    diese seite ist dafür sehr wichtig https://github.com/dirkhe/ioBroker.webcal/blob/master/doc/google.md

                    1 Reply Last reply Reply Quote 0
                    • liv-in-sky
                      liv-in-sky @andrenaether last edited by liv-in-sky

                      @andrenaether

                      das habe ich bis jetzt hinbekommen

                      Image 019.png

                      Image 020.png

                      A 1 Reply Last reply Reply Quote 0
                      • A
                        andrenaether @liv-in-sky last edited by

                        @liv-in-sky Ohh wow ich habe mich inzwischen auch damit befasst aber habe es nicht hinbekommen... 😥
                        Kannst du mir das zeigen, erklären .... bin da echt am verzweifeln .....
                        aber mega das es Leute wie dich gibt die da eine Ahnung haben 🙂

                        liv-in-sky 2 Replies Last reply Reply Quote 0
                        • liv-in-sky
                          liv-in-sky @andrenaether last edited by

                          @andrenaether sagte in Kalender von Website auslesen:

                          aber habe es nicht hinbekommen

                          was genau - den webcal adapter ?

                          A 1 Reply Last reply Reply Quote 0
                          • A
                            andrenaether @liv-in-sky last edited by

                            @liv-in-sky Und wie du die daten aus der website geholt hast .... Ich habe noch keinen Richtigen Plan wie das alles umsetzen und zusammenbauen ... 😨

                            liv-in-sky 1 Reply Last reply Reply Quote 0
                            • liv-in-sky
                              liv-in-sky @andrenaether last edited by

                              @andrenaether sagte in Kalender von Website auslesen:

                              Und wie du die daten aus der website geholt hast

                              das kommt noch - ich nutze ein script, welches du dann bekommst - zuerst muss aber der webcal adapter richtig eingerichtet werden

                              A 1 Reply Last reply Reply Quote 0
                              • liv-in-sky
                                liv-in-sky @andrenaether last edited by

                                @andrenaether sagte in Kalender von Website auslesen:

                                mega das es Leute wie dich gibt die da eine Ahnung haben

                                bei diesen ganzen google anmelde-kram habe ich nicht wirklich eine ahnung 🙂 habe nach anleitung solange geklickt, bis es lief

                                1 Reply Last reply Reply Quote 0
                                • A
                                  andrenaether @liv-in-sky last edited by

                                  @liv-in-sky Ich finde den Adapter nicht .... nur auf github .... Doch da lässt er sich nicht installieren über die url..... aber bin dran

                                  liv-in-sky A 2 Replies Last reply Reply Quote 0
                                  • liv-in-sky
                                    liv-in-sky @andrenaether last edited by

                                    @andrenaether zur not können wir auch mal eine anydesk session machen - da seh ich deinen bildschirm und wir können gemeinsam durchgehen, was zu machen ist

                                    1 Reply Last reply Reply Quote 0
                                    • A
                                      andrenaether @andrenaether last edited by andrenaether

                                      @andrenaether so Adapter habe ich und installiert ..... richte ihn gerade ein ... Habe heute wenig zeit ... muss gleich los ....
                                      Gruss andre 🙂

                                      D 1 Reply Last reply Reply Quote 0
                                      • D
                                        dirkhe Developer @andrenaether last edited by

                                        @andrenaether nimm die emai lieber raus und schreibe ihm per pn

                                        A 1 Reply Last reply Reply Quote 0
                                        • A
                                          andrenaether @dirkhe last edited by

                                          @dirkhe oh danke dir 🙂

                                          liv-in-sky 2 Replies Last reply Reply Quote 0
                                          • liv-in-sky
                                            liv-in-sky last edited by

                                            für später das sccript zum import - bitte noch nicht ausführen lassen - machen wir zusammen

                                            
                                            
                                            let url="https://irs.indico.ch/bodenseearena/views/Graphical?location=Bodenseearena"
                                            let gesucht;
                                            let theJson=[];let myCalArr=[];let myCalArrTomorrow=[];
                                            const myDP="0_userdata.0.CONTROL-OWN.AAATEST.testJSON"
                                            
                                            async function doit(){
                                            await getData();
                                            //log(gesucht[0])
                                            //log(String(gesucht.length))
                                            for(let i=0;i<gesucht.length;i++){
                                               let mytime=gesucht[i].replace(/.*new Date\((.*?)\).*/,"$1").split(",")
                                               let mydatum=mytime[2]+"."+String(Number(mytime[1])+1)+"."+mytime[0];
                                               let myzeit;
                                               let todayDay=formatDate(getDateObject((new Date().getTime())), "T.M.JJJJ");
                                               log(mydatum)
                                               mytime.length==4 ? myzeit=mytime[3]+":"+"00" : myzeit=mytime[3]+":"+mytime[4];
                                              //let mydauer=Number(gesucht[i].replace(/.*new Date\(.*?\)\, (.*?)\,.*/,"$1"))/100000;
                                               //log(mydauer)
                                               
                                             theJson.push({
                                                 "zeit":myzeit,
                                                 "datum":mydatum,
                                                 "ereignis":gesucht[i].replace(/.*[\'1\']\, \"(.*?)\"\, \"00000001\"\,.*/,"$1").replace(/\\r\\n/," ")
                                             })
                                             //if (i<5){
                                             myCalArr.push({
                                                 "start":mydatum+" "+ myzeit,
                                                 "end":mydatum+" "+ add15MinutesToTime(myzeit),
                                                 "summary":gesucht[i].replace(/.*[\'1\']\, \"(.*?)\"\, \"00000001\"\,.*/,"$1").replace(/\\r\\n/," "),
                                                 "description":"from IOB Script"
                                             })
                                             //log(todayDay+"   -   "+mydatum)
                                             if(todayDay===mydatum){
                                             myCalArrTomorrow.push({
                                                 "start":mydatum+" "+ myzeit,
                                                 "end":mydatum+" "+ add15MinutesToTime(myzeit),
                                                 "summary":gesucht[i].replace(/.*[\'1\']\, \"(.*?)\"\, \"00000001\"\,.*/,"$1").replace(/\\r\\n/," "),
                                                 "description":"from IOB Script"
                                             })}
                                             //}
                                            }
                                            //log(JSON.stringify(myCalArr));
                                            log(JSON.stringify(myCalArrTomorrow));
                                            
                                            setState(myDP,JSON.stringify(theJson));
                                            //toCalender(myCalArr);
                                            toCalender(myCalArrTomorrow);
                                            }
                                            
                                            
                                            async function getData(){
                                               return new Promise(async (resolve, reject) => {
                                            
                                              await request(url, async function (error, response, result) {
                                             
                                              gesucht="";
                                               const myregex = /^this\.AddAppointment.*$/gm;
                                              gesucht=result.match(myregex);  
                                             
                                                if (gesucht!="" && error==null) {resolve()} else {reject()}
                                            ;  }).on("error", function (e) {console.error(e);});
                                            
                                              
                                             });
                                            
                                            }
                                            
                                            schedule("1 5 * * *", async function () {
                                               doit(); 
                                            });
                                            
                                            
                                            
                                            function toCalender(myArr){
                                            sendTo("webcal.0", "addEvents", {
                                               calendar: "eislaufhalle",
                                               events: myArr
                                             })
                                             }
                                            
                                             function add15MinutesToTime(time) {
                                             const [hours, minutes] = time.split(":").map(Number);
                                            
                                             let totalMinutes = hours * 60 + minutes;
                                             totalMinutes += 30;
                                            
                                             const newHours = Math.floor(totalMinutes / 60);
                                             const newMinutes = totalMinutes % 60;
                                            
                                             const formattedNewHours = newHours < 10 ? `0${newHours}` : newHours;
                                             const formattedNewMinutes = newMinutes < 10 ? `0${newMinutes}` : newMinutes;
                                            
                                             return `${formattedNewHours}:${formattedNewMinutes}`;
                                            }
                                            
                                            
                                             
                                            
                                            

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            808
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            ical adapter kalender parser website auslesen
                                            3
                                            28
                                            1338
                                            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