Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Ical Setzen eines Events

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.1k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.1k

Ical Setzen eines Events

Scheduled Pinned Locked Moved Skripten / Logik
159 Posts 32 Posters 29.8k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • P Offline
    P Offline
    pix
    wrote on last edited by
    #19

    Hallo Sven,

    ich habe mal ein Skript für EINE Müllsorte (hier Papiermüll) gemacht.

    Das Skript prüft, ob Papiermüll im Kalender für <u>morgen</u> als Event steht. Wenn ja, setzt es den State javascript.INSTANZ.Muellwarnung.Papiermüll auf true. Ausserdem prüft es jeden Tag um 19:30Uhr ob dieser State true ist. Falls ja, schickt es eine Ansage an den Sayit-Adapter.

    ! ```
    /* Kalenderevent in der Zukunft suchen ! sucht im iCal Adapter nach events, die noch kommen http://forum.iobroker.net/viewtopic.php?f=21&t=3761&sid=4319378b32a0ce096bbbbfc0ebd859ce#p34975 ! 20.09.2016 erstellt von pix 13.11.2016 angepasst für Sven */ ! // User Anpassungen var suchstring = 'Papiermüll'; // Suchbegriff var stichtag = 1; // 0 heute; 1 morgen; 2 übermorgen; 3 In 3 Tagen var idTabelle = 'ical.0.data.table'; // Instanz eintragen var logging = true; // debug Log ein/ausschalten // Ende User Anpassungen ! createState('Muellwarnung.' + suchstring, false, { type: 'boolean', name: suchstring + ' wird morgen abgeholt', desc: suchstring + ' wird morgen abgeholt (Boolean)', def: false }); var idEventState = getState('Muellwarnung.' + suchstring).val; // am 27.11.2016 editiert ! var tage = ['Heute','Morgen','Übermorgen','In 3 Tagen']; // dafür relative Datumsangabe in iCal-Adapter einschalten und ggf. übersetzen ! function datum(x) { var jetzt = new Date(); if (logging) log('Jetztzeit: ' + jetzt); //var zeit = new Date(jetzt.getTime() + x * 24 * 60 * 60 * 1000); // es werden genau x Tage, als x * 24 Stunden zugezählt --> nicht gut var zeit = new Date (jetzt.getFullYear(), jetzt.getMonth(), jetzt.getDate() + x); // in drei Tagen um Mitternacht if (logging) log('Zielzeit: ' + zeit); var jahr = zeit.getFullYear(); var monat = (zeit.getMonth()+1 < 10) ? '0' + (zeit.getMonth()+1) : zeit.getMonth()+1; var tag = (zeit.getDate() < 10) ? '0' + zeit.getDate() : zeit.getDate(); return (tag + '.' + monat + '.' + jahr); } ! function pruefeKalender() { var kalender = getState(idTabelle).val; var tag = datum(parseInt(stichtag,10)); if (logging) log(tag); try{ var ereignisse = JSON.stringify(kalender, null, 2); // Ausgabe als String if (logging) log(ereignisse); for(var i = 0; i <kalender.length; 19/i++)/{/alle/events/durchgehen/if/(/(kalender[i].date.indexof(tag)/!="-1)" ||/(kalender[i].date.indexof(tage[stichtag])/)/string/datum/oder/relatives/(nicht/nicht)/gefunden,/also/gefunden/var/termin="kalender[i].event;" (termin.indexof(suchstring)/log('treffer:/'/+/tage[stichtag]/suchstring);/hier/wird/später/vielleicht/stichtag_array/verwendet/setstate(ideventstate,/true);/}/else/false);/catch/(fehler_try)/log('fehler/beim/kalenderevents/einlesen/fehler_try,/'error');/schedule("30/*/*",/function(){/bei/mehreren/müllskripts/den/ersten/wert/verändern/(minuten)/event="getState(idEventState).val;" (event)/ansage="suchstring" morgen/abholt./bitte/rausstellen!';/kann/sayit/push/gesetzt/werden/setstate("sayit.0.tts.text"/*text/to/speech*/,/ansage);/});/aktualisierung/on/({id:/idtabelle,/change:/'any'},/function(data)/pruefekalender();/1min/nach/mitternacht/schedule("1/pruefekalender);/skriptstart/<e=""></kalender.length;>
    ! Du musst für jede weitere Müllsorte das Skript duplizieren, umbenennen und anpassen.
    ! Zeile 011: suchstring muss im Kalendertext vorkommen
    ! Zeile 012: Stichtag 1 bedeutet morgen (erstmal lassen)
    ! Zeile 060: Schedule steht default auf 19Uhr 30min; sollte bei weiteren Skripts um je eine Minute verzögert werden (zB [i]"31 19 * * *"[/i]
    ! Berichte mal!
    ! Gruß
    ! Pix
    ! [color]
    ! EDIT 27.11.2016[/color] Zeile var idEventState = [color]getState([/color]'Muellwarnung.' + suchstring[color]).val[/color]; // am 27.11.2016 editiert[/i][/i][/i]

    ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

    1 Reply Last reply
    0
    • S Offline
      S Offline
      Sven2013
      wrote on last edited by
      #20

      Hallo Pix, vielen Dank für deine Arbeit.

      Ich habe es direkt ausprobiert, aber es scheint etwas noch nicht zu funktionieren.

      Hier das Fehlerlog aus dem Skript:

      9:25:00.770	[info]	javascript.1 Stop script script.js.Müllabholung_Papiermüll
      19:25:00.816	[info]	javascript.0 Start javascript script.js.Müllabholung_Papiermüll
      19:25:00.817	[info]	javascript.0 script.js.Müllabholung_Papiermüll: Jetztzeit: Sun Nov 13 2016 19:25:00 GMT+0100 (CET)
      19:25:00.817	[info]	javascript.0 script.js.Müllabholung_Papiermüll: Zielzeit: Mon Nov 14 2016 00:00:00 GMT+0100 (CET)
      19:25:00.818	[info]	javascript.0 script.js.Müllabholung_Papiermüll: 14.11.2016
      19:25:00.818	[info]	javascript.0 script.js.Müllabholung_Papiermüll: null
      19:25:00.818	[error]	javascript.0 script.js.Müllabholung_Papiermüll: Fehler beim Kalenderevents einlesen TypeError: Cannot read property 'length' of null
      19:25:00.818	[info]	javascript.0 script.js.Müllabholung_Papiermüll: registered 1 subscription and 2 schedules
      

      Im Kalender für morgen steht der Eintrag: EN Papier: Enger

      Die Zeile 12 habe ich auf "Papier" geändert.

      Warum steht da im Log: javascript.0 script.js.Müllabholung_Papiermüll: Jetztzeit: Sun Nov 13 2016 19:25:00 GMT+0100 (CET)

      Der Begriff Papiermüll taucht doch nirgends im script mehr auf?

      Unter Objekte steht:

      Muellwarnung

      Papier –- false

      Gruß Sven

      1 Reply Last reply
      0
      • P Offline
        P Offline
        pix
        wrote on last edited by
        #21

        Scheinbar wirft Zeile 44/45

        var ereignisse = JSON.stringify(kalender, null, 2); // Ausgabe als String
        if (logging) log(ereignisse);
        ````den Fehler __null__ aus.
        
        Dann kann das Skript nicht weitermachen.
        
        :?: Ist das Objekt __ical.0.data.table__ denn gefüllt? D.h. liefert der iCal-Adapter einen Kalender?
        ~~@Sven2013:~~ 
        
        > Die Zeile 12 habe ich auf "Papier" geändert. `  Du meinst Zeile 11, also````
        suchstring='Papier';
        

        Gruß

        Pix

        ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

        1 Reply Last reply
        0
        • S Offline
          S Offline
          Sven2013
          wrote on last edited by
          #22

          Hallo,

          ich vermute ich habe den Fehler grade entdeckt, es ist nicht ical.0 sondern ical.1 und da ist Data gefüllt.

          Was muss ich denn da in der Zeile 44/45 ändern?

          Gruß Sven

          1 Reply Last reply
          0
          • S Offline
            S Offline
            Sven2013
            wrote on last edited by
            #23

            Oh man bin ich doof…

            ich habe es gefunden natürlich ist die Instanz Oben zu ändern. Sorry...

            jetzt funktioniert es... Viele 1000 Dank dafür Pix!

            Gruß Sven

            1 Reply Last reply
            0
            • N Offline
              N Offline
              nathan1312
              wrote on last edited by
              #24

              Hallo,

              ich bin ein wenig am verzweifeln.

              ich habe das tolle Script von pix kopiert und lasse damit meine Kalendereinträge durchsuchen. Meine Anpassung:

              `/* Kalenderevent in der Zukunft suchen
              
              sucht im iCal Adapter nach events, die noch kommen
              http://forum.iobroker.net/viewtopic.php?f=21&t=3761&sid=4319378b32a0ce096bbbbfc0ebd859ce#p34975
              
              20.09.2016 erstellt von pix
              */
              
              // User Anpassungen
              var suchstring =   'BIOMUELL';              // Suchbegriff
              var stichtag =     1;                   // 0 heute;  1 morgen; 2 übermorgen; 3 In 3 Tagen
              var idTabelle =    'ical.0.data.table'; // Instanz eintragen
              var logging =      true;                // debug Log ein/ausschalten
              // Ende User Anpassungen
              
              createState(suchstring, false, {
                   type: 'boolean',
                   def: false
              });
              var idEventState = suchstring;
              
              var tage = ['Heute','Morgen','Übermorgen','In 3 Tagen']; // dafür relative Datumsangabe in iCal-Adapter einschalten und ggf. übersetzen
              
              function datum(x) {
                  var jetzt = new Date();
                  if (logging) log('Jetztzeit: ' + jetzt);
                  //var zeit = new Date(jetzt.getTime() + x * 24 * 60 * 60 * 1000); // es werden genau x Tage, als x * 24 Stunden zugezählt --> nicht gut
                  var zeit = new Date (jetzt.getFullYear(), jetzt.getMonth(), jetzt.getDate() + x); // in drei Tagen um Mitternacht
                  if (logging) log('Zielzeit: ' + zeit);
                  var jahr       = zeit.getFullYear();
                  var monat      = (zeit.getMonth()+1 < 10) ? '0' + (zeit.getMonth()+1) : zeit.getMonth()+1;
                  var tag        = (zeit.getDate() < 10) ? '0' + zeit.getDate() : zeit.getDate();
                  return (tag + '.' + monat + '.' + jahr);
              }
              
              function pruefeKalender() {
                  var kalender = getState(idTabelle).val;
                  var tag = datum(parseInt(stichtag,10));
                  if (logging) log(tag);
                  try{
                      var ereignisse = JSON.stringify(kalender, null, 2); // Ausgabe als String
                      if (logging) log(ereignisse);
                      for(var i = 0; i <kalender.length; i++)/{/alle/events/durchgehen/if/(/(kalender[i].date.indexof(tag)/!="-1)" ||/(kalender[i].date.indexof(tage[stichtag])/)/string/datum/oder/relatives/(nicht/nicht)/gefunden,/also/gefunden/var/termin="kalender[i].event;" (termin.indexof(suchstring)/log('treffer:/'/+/tage[stichtag]/suchstring);/setstate(ideventstate,true);/weitere/aktionen,/setstate/so/}/else/setstate(ideventstate,false);/catch/(fehler_try)/log('fehler/beim/kalenderevents/einlesen/fehler_try,/'error');/bei/aktualisierung/on/({id:/idtabelle,/change:/'any'},/function(data)/pruefekalender();/});/1min/nach/mitternacht/schedule("1/*/*",/pruefekalender);/skriptstart/pruefekalender();<e=""></kalender.length;>`
              
              Beim Ausführen erhalte ich folgendes log:
              
              `~~[code]~~12:20:43.443	[info]	javascript.0 Stop script script.js.Müllerinnerung.Biomüll
              12:20:43.484	[info]	javascript.0 Start javascript script.js.Müllerinnerung.Biomüll
              12:20:43.484	[info]	javascript.0 script.js.Müllerinnerung.Biomüll: Jetztzeit: Sun Nov 27 2016 12:20:43 GMT+0100 (CET)
              12:20:43.485	[info]	javascript.0 script.js.Müllerinnerung.Biomüll: Zielzeit: Mon Nov 28 2016 00:00:00 GMT+0100 (CET)
              12:20:43.485	[info]	javascript.0 script.js.Müllerinnerung.Biomüll: 28.11.2016
              12:20:43.485	[info]	javascript.0 script.js.Müllerinnerung.Biomüll: [XXX]
              12:20:43.486	[info]	javascript.0 script.js.Müllerinnerung.Biomüll: Treffer: Morgen BIOMUELL
              12:20:43.486	[info]	javascript.0 script.js.Müllerinnerung.Biomüll: registered 1 subscription and 1 schedule[/code]`
              
              So wie ich das verstehe, erzeugt das Script einen "Treffer" für "Morgen BIOMUELL", jedoch wird die definierte Variable "BIOMUELL" nicht auf "true" gesetzt. Diese bleibt hartnäckig auf "false" stehen  :evil: 
              
              Kann mir jemand helfen? Wo hab ich einen Fehler gemacht...?  :? 
              
              Beste Grüße![/i][/i][/i]
              
              1 Reply Last reply
              0
              • N Offline
                N Offline
                nathan1312
                wrote on last edited by
                #25

                …hatte gerade mal zum Test den Debug-Mode angeschaltet. Da erhalte ich folgendes log:

                javascript.0	2016-11-27 12:34:20.434	info	script.js.Müllerinnerung.Biomüll: registered 1 subscription and 1 schedule
                javascript.0	2016-11-27 12:34:20.434	warn	script.js.Müllerinnerung.Biomüll: setForeignState(id=javascript.0.BIOMUELL, state=false) - was not executed, while debug mode is active
                javascript.0	2016-11-27 12:34:20.433	warn	script.js.Müllerinnerung.Biomüll: setForeignState(id=javascript.0.BIOMUELL, state=false) - was not executed, while debug mode is active
                javascript.0	2016-11-27 12:34:20.433	warn	script.js.Müllerinnerung.Biomüll: setForeignState(id=javascript.0.BIOMUELL, state=true) - was not executed, while debug mode is active
                javascript.0	2016-11-27 12:34:20.433	info	script.js.Müllerinnerung.Biomüll: Treffer: Morgen BIOMUELL
                javascript.0	2016-11-27 12:34:20.432	warn	script.js.Müllerinnerung.Biomüll: setForeignState(id=javascript.0.BIOMUELL, state=false) - was not executed, while debug mode is active
                

                Anscheinend wird die Variable kurz auf "true" geschaltet, allerdings danach sofort (zweimal) wieder auf "false". Ich verstehe das Script leider nicht in allen Teilen so gut und kann nicht erkennen wodurch das ausgelöst wird…

                1 Reply Last reply
                0
                • P Offline
                  P Offline
                  pix
                  wrote on last edited by
                  #26

                  Hallo,

                  ich habe das Skript nochmal durchegesehen und einen Fehler gefunden:

                  die idEventState ist ein __boolea__n und wird in einer fälschlicherweise mit einem String gefüllt.

                  also richtig:

                  var idEventState = getState('Muellwarnung.' + suchstring).val; // am 27.11.2016 editiert
                  

                  oder bei dir nathan1312

                  var idEventState = getState(suchstring).val;
                  

                  Gruß

                  Pix

                  ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

                  1 Reply Last reply
                  0
                  • N Offline
                    N Offline
                    nathan1312
                    wrote on last edited by
                    #27

                    Hi Pix,

                    Danke für die Antwort. Ich glaube leider nur, dass das was du geschrieben hast keinen Sinn macht. Ich hab die Änderung auch mal ausprobiert und es hat nicht funktioniert.

                    Könntest du nochmal über das Script gucken ob nicht doch ein anderer Fehler enthalten ist.

                    Wäre sehr nett!

                    Beste grüße!

                    Gesendet von meinem SGP511 mit Tapatalk

                    1 Reply Last reply
                    0
                    • S Offline
                      S Offline
                      Sven2013
                      wrote on last edited by
                      #28

                      Hallo Pix,

                      ich setze dein Script erfolgreich für meine Müllüberwachung ein. Allerdings ist mir nun aufgefallen, dass die letzte gefundene Mülltonne ab Ihrer Leerung jeden Tag angesagt wird, bis eine andere dran ist. Dann wird diese jeden Tag angesagt..

                      Also eigentlich alles korrekt, bis auf das scheinbar die Variable nicht zurück gesetzt wird.

                      Kannst du da nochmal ins Script schauen, ob du da etwas diesbezüglich findest?

                      Hier zur Sicherheit nochmal das aktuell verwendete:

                      `/* Kalenderevent in der Zukunft suchen
                      
                      sucht im iCal Adapter nach events, die noch kommen
                      http://forum.iobroker.net/viewtopic.php?f=21&t=3761&sid=4319378b32a0ce096bbbbfc0ebd859ce#p34975
                      
                      20.09.2016 erstellt von pix
                      13.11.2016 angepasst für Sven
                      */
                      
                      // User Anpassungen
                      var suchstring =   'Bio';              // Suchbegriff
                      var stichtag =     1;                   // 0 heute;  1 morgen; 2 übermorgen; 3 In 3 Tagen
                      var idTabelle =    'ical.1.data.table'; // Instanz eintragen
                      var logging =      true;                // debug Log ein/ausschalten
                      // Ende User Anpassungen
                      
                      createState('Muellwarnung.' + suchstring, false, {
                           type: 'boolean',
                           name: suchstring + ' wird morgen abgeholt',
                           desc: suchstring + ' wird morgen abgeholt (Boolean)',
                           def: false
                      });
                      var idEventState = 'Muellwarnung.' + suchstring;
                      
                      var tage = ['Heute','Morgen','Übermorgen','In 3 Tagen']; // dafür relative Datumsangabe in iCal-Adapter einschalten und ggf. übersetzen
                      
                      function datum(x) {
                          var jetzt = new Date();
                          if (logging) log('Jetztzeit: ' + jetzt);
                          //var zeit = new Date(jetzt.getTime() + x * 24 * 60 * 60 * 1000); // es werden genau x Tage, als x * 24 Stunden zugezählt --> nicht gut
                          var zeit = new Date (jetzt.getFullYear(), jetzt.getMonth(), jetzt.getDate() + x); // in drei Tagen um Mitternacht
                          if (logging) log('Zielzeit: ' + zeit);
                          var jahr       = zeit.getFullYear();
                          var monat      = (zeit.getMonth()+1 < 10) ? '0' + (zeit.getMonth()+1) : zeit.getMonth()+1;
                          var tag        = (zeit.getDate() < 10) ? '0' + zeit.getDate() : zeit.getDate();
                          return (tag + '.' + monat + '.' + jahr);
                      }
                      
                      function pruefeKalender() {
                          var kalender = getState(idTabelle).val;
                          var tag = datum(parseInt(stichtag,10));
                          if (logging) log(tag);
                          try{
                              var ereignisse = JSON.stringify(kalender, null, 2); // Ausgabe als String
                              if (logging) log(ereignisse);
                              for(var i = 0; i <kalender.length; 20/i++)/{/alle/events/durchgehen/if/(/(kalender[i].date.indexof(tag)/!="-1)" ||/(kalender[i].date.indexof(tage[stichtag])/)/string/datum/oder/relatives/(nicht/nicht)/gefunden,/also/gefunden/var/termin="kalender[i].event;" (termin.indexof(suchstring)/log('treffer:/'/+/tage[stichtag]/suchstring);/hier/wird/später/vielleicht/stichtag_array/verwendet/setstate(ideventstate,/true);/}/else/false);/catch/(fehler_try)/log('fehler/beim/kalenderevents/einlesen/fehler_try,/'error');/schedule("34/*/*",/function(){/bei/mehreren/müllskripts/den/ersten/wert/verändern/(minuten)/event="getState(idEventState).val;" (event)/ansage="suchstring" morgen/abholt./bitte/rausstellen!';/kann/sayit/push/gesetzt/werden/setstate("sayit.0.tts.text"/*text/to/speech*/,/ansage);/});/aktualisierung/on/({id:/idtabelle,/change:/'any'},/function(data)/pruefekalender();/1min/nach/mitternacht/schedule("1/pruefekalender);/skriptstart/<e=""></kalender.length;>`
                      
                      Danke, Gruß Sven[/i][/i][/i]
                      
                      1 Reply Last reply
                      0
                      • P Offline
                        P Offline
                        pix
                        wrote on last edited by
                        #29

                        Hallo Sven,

                        kannst du mir noch den Inhalt von

                        ical.1.data.table
                        ````posten. Kann das so nicht reproduzieren.
                        
                        Gruß
                        
                        Pix
                        
                        PS: Danke, dass du dein aktuell verwendetes Skript mit in die Frage postest. Damit ist es viel einfacher.

                        ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

                        1 Reply Last reply
                        0
                        • S Offline
                          S Offline
                          Sven_Tengeler
                          wrote on last edited by
                          #30

                          Gerne,

                          steht folgendes drin:

                          [object Object],[object Object],[object Object]

                          Gruß Sven

                          Gesendet von iPhone mit Tapatalk

                          1 Reply Last reply
                          0
                          • C Offline
                            C Offline
                            charlyphyro
                            wrote on last edited by
                            #31

                            Hallo Pix,

                            Bei mir tritt der Fehler auch auf. Skript ist gleich beim Sven2013 & die data.table ist je nach dem wieviele Ereignisse anstehen mit mehr oder weniger [object Object].

                            Habe testweise den Bio auf morgen datiert. Ist auf true. Man sieht auch im log das er die Zielzeit und Jetztzeit gespeichert worden ist & auch abgerufen wird, obwohl der Datenpunkt gelöscht worden ist.

                            Hoffe das hilft dir einwenig mehr 🙂

                            Logdatei:

                            ! charlyphyro 2016-12-05 12:05:07.330 info host.charlyphyro instance system.adapter.ical.0 terminated with code 0 (OK)
                            ! javascript.1 2016-12-05 12:05:01.807 info javascript.1 script.js.JAVA_1.Müllansage_Bio: [ { 'date': 'In 4 Tagen 18:00-19:00', 'event': 'Restmüll', '_class': 'ical_Müll 2 ical_4days', '_date': '2016-12-09T17:00:00.000Z', '_end': '2016-12-09T18:00:00.000Z', '_IDID': '1FE329DE-75E7-4619-8CE2-0AEBC865679C', '_allDay': false, '_rule': ' ', '_calName': 'Müll 2' }, { 'date': '16.12.2016 18:00-19:00', 'event': 'Bio', '_class': 'ical_Müll 2 ', '_date': '2016-12-16T17:00:00.000Z', '_end': '2016-12-16T18:00:00.000Z', '_IDID': '9E523031-50E4-45E9-B851-D3D16AB9B47F', '_allDay': false, '_rule': ' ', '_calName': 'Müll 2' } ]
                            ! javascript.1 2016-12-05 12:05:01.807 info javascript.1 script.js.JAVA_1.Müllansage_Bio: 06.12.2016
                            ! javascript.1 2016-12-05 12:05:01.807 info javascript.1 script.js.JAVA_1.Müllansage_Bio: Zielzeit: Tue Dec 06 2016 00:00:00 GMT+0100 (CET)
                            ! javascript.1 2016-12-05 12:05:01.806 info javascript.1 script.js.JAVA_1.Müllansage_Bio: Jetztzeit: Mon Dec 05 2016 12:05:01 GMT+0100 (CET)
                            ! ical.0 2016-12-05 12:05:01.805 info ical.0 processing URL: Müll http://p31-calendars.icloud.com/published/2/XXXXXXX
                            ! ical.0 2016-12-05 12:05:01.805 info ical.0 processing URL: Müll 2 http://p31-calendars.icloud.com/published/2/XXXXXX
                            ! ical.0 2016-12-05 12:05:00.640 info ical.0 starting. Version 1.2.0 in /opt/iobroker/node_modules/iobroker.ical, node: v4.6.2
                            ! charlyphyro 2016-12-05 12:05:00.229 info host.charlyphyro instance system.adapter.ical.0 started with pid 13907
                            ! javascript.0 2016-12-05 12:04:52.423 info javascript.0 script.js.JAVA_0.Stromzähler: nach entferne Datenpunkt: Trockner Messung
                            ! javascript.0 2016-12-05 12:04:21.863 info script.js.JAVA_0.Stromzähler: nach entferne Datenpunkt: Stromzaehler
                            ! host.charlyphyro 2016-12-05 12:04:07.218 info instance system.adapter.ical.0 terminated with code 0 (OK)
                            ! javascript.1 2016-12-05 12:04:01.695 info ]
                            ! javascript.1 2016-12-05 12:04:01.695 info }
                            ! javascript.1 2016-12-05 12:04:01.695 info '_calName': 'Müll 2'
                            ! javascript.1 2016-12-05 12:04:01.695 info '_rule': ' ',
                            ! javascript.1 2016-12-05 12:04:01.695 info '_allDay': false,
                            ! javascript.1 2016-12-05 12:04:01.695 info '_IDID': '9E523031-50E4-45E9-B851-D3D16AB9B47F',
                            ! javascript.1 2016-12-05 12:04:01.695 info '_end': '2016-12-16T18:00:00.000Z',
                            ! javascript.1 2016-12-05 12:04:01.695 info '_date': '2016-12-16T17:00:00.000Z',
                            ! javascript.1 2016-12-05 12:04:01.695 info '_class': 'ical_Müll 2 ',
                            ! javascript.1 2016-12-05 12:04:01.695 info 'event': 'Bio',
                            ! javascript.1 2016-12-05 12:04:01.695 info 'date': '16.12.2016 18:00-19:00',
                            ! javascript.1 2016-12-05 12:04:01.695 info {
                            ! javascript.1 2016-12-05 12:04:01.695 info },
                            ! javascript.1 2016-12-05 12:04:01.695 info '_calName': 'Müll 2'
                            ! javascript.1 2016-12-05 12:04:01.695 info '_rule': ' ',
                            ! javascript.1 2016-12-05 12:04:01.695 info '_allDay': false,
                            ! javascript.1 2016-12-05 12:04:01.695 info '_IDID': '1FE329DE-75E7-4619-8CE2-0AEBC865679C',
                            ! javascript.1 2016-12-05 12:04:01.695 info '_end': '2016-12-09T18:00:00.000Z',
                            ! javascript.1 2016-12-05 12:04:01.695 info '_date': '2016-12-09T17:00:00.000Z',
                            ! javascript.1 2016-12-05 12:04:01.695 info '_class': 'ical_Müll 2 ical_4days',
                            ! javascript.1 2016-12-05 12:04:01.695 info 'event': 'Restmüll',
                            ! javascript.1 2016-12-05 12:04:01.695 info 'date': 'In 4 Tagen 18:00-19:00',
                            ! javascript.1 2016-12-05 12:04:01.695 info {
                            ! javascript.1 2016-12-05 12:04:01.695 info script.js.JAVA_1.Müllansage_Bio: [
                            ! javascript.1 2016-12-05 12:04:01.695 info script.js.JAVA_1.Müllansage_Bio: 06.12.2016
                            ! javascript.1 2016-12-05 12:04:01.695 info script.js.JAVA_1.Müllansage_Bio: Zielzeit: Tue Dec 06 2016 00:00:00 GMT+0100 (CET)
                            ! javascript.1 2016-12-05 12:04:01.695 info script.js.JAVA_1.Müllansage_Bio: Jetztzeit: Mon Dec 05 2016 12:04:01 GMT+0100 (CET)
                            ! ical.0 2016-12-05 12:04:01.682 info processing URL: Müll http://p31-calendars.icloud.com/published/2/XXXXXXX
                            ! ical.0 2016-12-05 12:04:01.673 info processing URL: Müll 2 http://p31-calendars.icloud.com/published/2/XXXXXX
                            ! ical.0 2016-12-05 12:04:00.631 info starting. Version 1.2.0 in /opt/iobroker/node_modules/iobroker.ical, node: v4.6.2
                            ! host.charlyphyro 2016-12-05 12:04:00.230 info instance system.adapter.ical.0 started with pid 13895

                            1 Reply Last reply
                            0
                            • N Offline
                              N Offline
                              nathan1312
                              wrote on last edited by
                              #32

                              Hallo,

                              ich glaube nach langen Suchen hab ich den Fehler gefunden:

                              `function pruefeKalender() {
                                  var kalender = getState(idTabelle).val;
                                  var tag = datum(parseInt(stichtag,10));
                                  if (logging) log(tag);
                                  try{
                                      var ereignisse = JSON.stringify(kalender, null, 2); // Ausgabe als String
                                      if (logging) log(ereignisse);
                                      for(var i = 0; i <kalender.length; i++)/{/alle/events/durchgehen/if/(/(kalender[i].date.indexof(tag)/!="-1)" ||/(kalender[i].date.indexof(tage[stichtag])/)/string/datum/oder/relatives/(nicht/nicht)/gefunden,/also/gefunden/var/termin="kalender[i].event;" (termin.indexof(suchstring)/log('treffer:/'/+/tage[stichtag]/suchstring);/setstate(suchstring,/true);/}/else/false);/catch/(fehler_try)/log('fehler/beim/kalenderevents/einlesen/fehler_try,/'error');/}<e=""></kalender.length;>`
                              
                              Der "else"-Teil saß an der falschen Stelle des Scripts glaube ich. So wie ich das interpretiertt hab handelt es sich um eine verschachtelte Doppelbedingung. Zunächst wird der Zeitrtaum geprüft `~~[code]~~if ( (kalender[i].date.indexOf(tag) != -1) || (kalender[i].date.indexOf(tage[stichtag]) != -1)` und danach das Event `~~[code]~~ if (termin.indexOf(suchstring) != -1)[/code]`.
                              
                              Der "else"-Teil muss demnach eine geschweifte Klammer später auftauchen. Ansonsten wird die zweite Bedingung erst gar nicht durchlaufen und der Status der Systemvariable wird nicht wieder zurück gesetzt.
                              
                              Bei mir scheint es mit der Änderung jetzt zu funktionieren. Vielleicht kann pix meine Vermutung nur zur Sicherheit nochmal überprüfen und ggf. bestätigen. ...oder auch schreiben, dass das alles Quatsch ist was ich hier behaupte.  ;) 
                              
                              Beste Grüße![/i][/i][/code][/i][/i][/i]
                              
                              1 Reply Last reply
                              0
                              • H Offline
                                H Offline
                                hanisoft
                                wrote on last edited by
                                #33

                                Hallo,

                                Hallo,

                                ich hab einmal alle Änderungen übernommen. Scheint auch etwas zu funktionieren. Das Event wird gefunden, lt Log.

                                Trotzdem hab ich im Log einen Warnung: State "RM" not found. und in Objekte bleibt der Wert immer auf false.

                                Hier mein Script

                                ! // User Anpassungen
                                ! var suchstring = 'AP'; // Suchbegriff
                                ! var stichtag = 1; // 0 heute; 1 morgen; 2 übermorgen; 3 In 3 Tagen
                                ! var idTabelle = 'ical.0.data.table'; // Instanz eintragen
                                ! var logging = true; // debug Log ein/ausschalten
                                ! // Ende User Anpassungen
                                ! createState('Muellwarnung.' + suchstring, false, {
                                ! type: 'boolean',
                                ! name: suchstring + ' wird morgen abgeholt',
                                ! desc: suchstring + ' wird morgen abgeholt (Boolean)',
                                ! def: false
                                ! });
                                ! var idEventState = getState('Muellwarnung.' + suchstring).val; // am 27.11.2016 editiert
                                ! var tage = ['Heute','Morgen','Übermorgen','In 3 Tagen']; // dafür relative Datumsangabe in iCal-Adapter einschalten und ggf. übersetzen
                                ! function datum(x) {
                                ! var jetzt = new Date();
                                ! if (logging) log('Jetztzeit: ' + jetzt);
                                ! //var zeit = new Date(jetzt.getTime() + x * 24 * 60 * 60 * 1000); // es werden genau x Tage, als x * 24 Stunden zugezählt –> nicht gut
                                ! var zeit = new Date (jetzt.getFullYear(), jetzt.getMonth(), jetzt.getDate() + x); // in drei Tagen um Mitternacht
                                ! if (logging) log('Zielzeit: ' + zeit);
                                ! var jahr = zeit.getFullYear();
                                ! var monat = (zeit.getMonth()+1 < 10) ? '0' + (zeit.getMonth()+1) : zeit.getMonth()+1;
                                ! var tag = (zeit.getDate() < 10) ? '0' + zeit.getDate() : zeit.getDate();
                                ! return (tag + '.' + monat + '.' + jahr);
                                ! }
                                ! function pruefeKalender() {
                                ! var kalender = getState(idTabelle).val;
                                ! var tag = datum(parseInt(stichtag,10));
                                ! if (logging) log(tag);
                                ! try{
                                ! var ereignisse = JSON.stringify(kalender, null, 2); // Ausgabe als String
                                ! if (logging) log(ereignisse);
                                ! for(var i = 0; i <kalender.length; i++)/{/alle/events/durchgehen<br="">if ( (kalender__.date.indexOf(tag) != -1) || (kalender__.date.indexOf(tage[stichtag]) != -1) ) { // String Datum oder relatives Datum (nicht nicht) gefunden, also gefunden
                                ! var termin = kalender__.event;
                                ! if (termin.indexOf(suchstring) != -1) {
                                ! log('Treffer: ' + tage[stichtag] + ' ' + suchstring); // hier wird später vielleicht stichtag_array verwendet
                                ! setState(idEventState, true);
                                ! } else setState(idEventState, false);
                                ! }
                                ! }
                                ! } catch (fehler_try) {
                                ! log('Fehler beim Kalenderevents einlesen ' + fehler_try, 'error');
                                ! }
                                ! }
                                ! schedule("32 19 * * *", function(){ // bei mehreren Müllskripts den ersten Wert verändern (Minuten)
                                ! var event = getState(idEventState).val;
                                ! if (event) {
                                ! var ansage = suchstring + ' wird morgen abholt. Bitte rausstellen!';
                                ! // hier kann sayit oder push gesetzt werden
                                ! setState("sayit.0.tts.text"/Text to speech/, ansage);
                                ! }
                                ! });
                                ! // bei Aktualisierung
                                ! on ({id: idTabelle, change: 'any'}, function(data) {
                                ! pruefeKalender();
                                ! });
                                ! // 1Min nach Mitternacht
                                ! schedule("1 * * * *", pruefeKalender);
                                ! //bei Skriptstart
                                ! pruefeKalender();______</kalender.length;> ______Danke für Eure Hilfe

                                Gruß

                                Hannes______

                                1 Reply Last reply
                                0
                                • N Offline
                                  N Offline
                                  nathan1312
                                  wrote on last edited by
                                  #34

                                  Ich hab glaub ich noch was raus gefunden:

                                  Kann es sein, dass Script alle Einträge durchläuft und jedesmal die angelegte variable neu setzt? Das bedeutet, dass wenn das event im ersten Eintrag gefunden wird, geht der State auf true. Dann wird aber weiter gesucht und da im zweiten kalendereintrag der suchtext dann natürlich nicht mehr auftritt wird der State wieder auf false gesetzt.

                                  Abhilfe könnte hier der Befehl "break" geben (nach dem Befehl zum setzen der variable auf true eingesetzt). Ich hab das Script im Moment so am laufen. Bis jetzt klappts…

                                  Beste grüße!

                                  Gesendet von meinem D5803 mit Tapatalk

                                  1 Reply Last reply
                                  0
                                  • P Offline
                                    P Offline
                                    pix
                                    wrote on last edited by
                                    #35

                                    Liebe Leute,

                                    ich kann die Fehler leider nicht reproduzieren, da der Datenpunkt table innerhalb meines ical-Adapters nicht mehr gefüllt wird (readme auf github sagt nix dazu). Auch hatte ich das Skript nie selbst im Einsatz, es wurde hergeleitet aus einem anderen Skript zum Ansagen von Geburtstagen am kommenden Tag, das zusammen mit einem anderen User (PrinzEisenherz) entwickelt wurde.

                                    @nathan: Du hast recht, wenn weitere Kalendereinträge aufkommen, die nicht dem Suchwort entsprechen, wird die Variable fälschlicherweise auf false gesetzt.

                                    Sollte der Adapter table mal wieder korrekt füllen, kann ich das Skript gern nochmal ausprobieren.

                                    Gruß

                                    Pix

                                    ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

                                    1 Reply Last reply
                                    0
                                    • C Offline
                                      C Offline
                                      chris
                                      wrote on last edited by
                                      #36

                                      Hallo

                                      ich habe das Script so genommen wie Pix es für Altpapier geschrieben hatte.

                                      idEventState blieb auch immer aus false.

                                      Oben habe ich noch eine Zeile eingefügt. Seit dem läuft es bei mir.

                                      var idEventState = 'Muellwarnung.' + suchstring;
                                      setState(idEventState, false); 
                                      

                                      Gruß

                                      Chris

                                      1 Reply Last reply
                                      0
                                      • H Offline
                                        H Offline
                                        hanisoft
                                        wrote on last edited by
                                        #37

                                        Hallo,

                                        wo hast Du das genau eingesetzt?

                                        Danke

                                        Gruß

                                        Hannes

                                        1 Reply Last reply
                                        0
                                        • S Offline
                                          S Offline
                                          Sven2013
                                          wrote on last edited by
                                          #38

                                          Hallo Pix, Hallo @all

                                          ich habe nun beide Varianten die in den oben genannte Variante von Nathan1312 ausprobiert:

                                          Erfolg: Die Variablen beleiben auf "false"

                                          dann habe ich in Zeile 24 die Ergänzung von Chris eingefügt:

                                          Erfolg: Das Script findet die Müllabholung von Morgen korrekt. Ansage erfolgt ebenfalls korrekt. Die Variable wird danach aber leider nicht wieder auf false gestzt wenn der Tag des Mülls dran war. Kommt dann ein Anderer Müll, wird Sie auf false gesetzt und das ganze Spiel beginnt mit der anderen Müllart wie beschrieben von Vorne.

                                          Vielleicht kann jemand von euch mit der Beschreibung etwas anfangen…

                                          Denn wenn es geht ist es eine tolle Erleichterung damit ich den Müll nicht mehr so oft vergesse 🙂

                                          `/* Kalenderevent in der Zukunft suchen
                                          
                                          sucht im iCal Adapter nach events, die noch kommen
                                          http://forum.iobroker.net/viewtopic.php?f=21&t=3761&sid=4319378b32a0ce096bbbbfc0ebd859ce#p34975
                                          
                                          20.09.2016 erstellt von pix
                                          13.11.2016 angepasst für Sven
                                          */
                                          
                                          // User Anpassungen
                                          var suchstring =   'Rest';              // Suchbegriff
                                          var stichtag =     1;                   // 0 heute;  1 morgen; 2 übermorgen; 3 In 3 Tagen
                                          var idTabelle =    'ical.1.data.table'; // Instanz eintragen
                                          var logging =      true;                // debug Log ein/ausschalten
                                          // Ende User Anpassungen
                                          
                                          createState('Muellwarnung.' + suchstring, false, {
                                               type: 'boolean',
                                               name: suchstring + ' wird morgen abgeholt',
                                               desc: suchstring + ' wird morgen abgeholt (Boolean)',
                                               def: false
                                          });
                                          var idEventState = 'Muellwarnung.' + suchstring;
                                          setState(idEventState, false); 
                                          
                                          var tage = ['Heute','Morgen','Übermorgen','In 3 Tagen']; // dafür relative Datumsangabe in iCal-Adapter einschalten und ggf. übersetzen
                                          
                                          function datum(x) {
                                              var jetzt = new Date();
                                              if (logging) log('Jetztzeit: ' + jetzt);
                                              //var zeit = new Date(jetzt.getTime() + x * 24 * 60 * 60 * 1000); // es werden genau x Tage, als x * 24 Stunden zugezählt --> nicht gut
                                              var zeit = new Date (jetzt.getFullYear(), jetzt.getMonth(), jetzt.getDate() + x); // in drei Tagen um Mitternacht
                                              if (logging) log('Zielzeit: ' + zeit);
                                              var jahr       = zeit.getFullYear();
                                              var monat      = (zeit.getMonth()+1 < 10) ? '0' + (zeit.getMonth()+1) : zeit.getMonth()+1;
                                              var tag        = (zeit.getDate() < 10) ? '0' + zeit.getDate() : zeit.getDate();
                                              return (tag + '.' + monat + '.' + jahr);
                                          }
                                          
                                          function pruefeKalender() {
                                              var kalender = getState(idTabelle).val;
                                              var tag = datum(parseInt(stichtag,10));
                                              if (logging) log(tag);
                                              try{
                                                  var ereignisse = JSON.stringify(kalender, null, 2); // Ausgabe als String
                                                  if (logging) log(ereignisse);
                                                  for(var i = 0; i <kalender.length; 20/i++)/{/alle/events/durchgehen/if/(/(kalender[i].date.indexof(tag)/!="-1)" ||/(kalender[i].date.indexof(tage[stichtag])/)/string/datum/oder/relatives/(nicht/nicht)/gefunden,/also/gefunden/var/termin="kalender[i].event;" (termin.indexof(suchstring)/log('treffer:/'/+/tage[stichtag]/suchstring);/hier/wird/später/vielleicht/stichtag_array/verwendet/setstate(ideventstate,/true);/}/else/false);/catch/(fehler_try)/log('fehler/beim/kalenderevents/einlesen/fehler_try,/'error');/schedule("30/*/*",/function(){/bei/mehreren/müllskripts/den/ersten/wert/verändern/(minuten)/event="getState(idEventState).val;" (event)/ansage="suchstring" mülltonne/morgen/abgeholt./bitte/stell/die/tonne/an/straße!';/kann/sayit/push/gesetzt/werden/setstate("sayit.0.tts.text"/*text/to/speech*/,/ansage);/});/aktualisierung/on/({id:/idtabelle,/change:/'any'},/function(data)/pruefekalender();/1min/nach/mitternacht/schedule("1/pruefekalender);/skriptstart/<e=""></kalender.length;>`
                                          
                                          Gruß Sven[/i][/i][/i]
                                          
                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          746

                                          Online

                                          32.4k

                                          Users

                                          81.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe