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 Setzen eines Events

NEWS

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

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

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

Ical Setzen eines Events

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
159 Beiträge 32 Kommentatoren 29.8k Aufrufe 2 Watching
  • Ä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.
  • N Offline
    N Offline
    nathan1312
    schrieb am zuletzt editiert von
    #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 Antwort Letzte Antwort
    0
    • P Offline
      P Offline
      pix
      schrieb am zuletzt editiert von
      #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 Antwort Letzte Antwort
      0
      • N Offline
        N Offline
        nathan1312
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        0
        • S Offline
          S Offline
          Sven2013
          schrieb am zuletzt editiert von
          #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 Antwort Letzte Antwort
          0
          • P Offline
            P Offline
            pix
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            0
            • S Offline
              S Offline
              Sven_Tengeler
              schrieb am zuletzt editiert von
              #30

              Gerne,

              steht folgendes drin:

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

              Gruß Sven

              Gesendet von iPhone mit Tapatalk

              1 Antwort Letzte Antwort
              0
              • C Offline
                C Offline
                charlyphyro
                schrieb am zuletzt editiert von
                #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 Antwort Letzte Antwort
                0
                • N Offline
                  N Offline
                  nathan1312
                  schrieb am zuletzt editiert von
                  #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 Antwort Letzte Antwort
                  0
                  • H Offline
                    H Offline
                    hanisoft
                    schrieb am zuletzt editiert von
                    #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 Antwort Letzte Antwort
                    0
                    • N Offline
                      N Offline
                      nathan1312
                      schrieb am zuletzt editiert von
                      #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 Antwort Letzte Antwort
                      0
                      • P Offline
                        P Offline
                        pix
                        schrieb am zuletzt editiert von
                        #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 Antwort Letzte Antwort
                        0
                        • C Offline
                          C Offline
                          chris
                          schrieb am zuletzt editiert von
                          #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 Antwort Letzte Antwort
                          0
                          • H Offline
                            H Offline
                            hanisoft
                            schrieb am zuletzt editiert von
                            #37

                            Hallo,

                            wo hast Du das genau eingesetzt?

                            Danke

                            Gruß

                            Hannes

                            1 Antwort Letzte Antwort
                            0
                            • S Offline
                              S Offline
                              Sven2013
                              schrieb am zuletzt editiert von
                              #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 Antwort Letzte Antwort
                              0
                              • wendy2702W Online
                                wendy2702W Online
                                wendy2702
                                schrieb am zuletzt editiert von
                                #39

                                @chris:

                                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 `

                                Hi,

                                kannst du vielleicht mal das komplette Script posten?

                                Danke und Gruß

                                Mirko

                                Bitte keine Fragen per PN, die gehören ins Forum!

                                Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                1 Antwort Letzte Antwort
                                0
                                • C Offline
                                  C Offline
                                  chris
                                  schrieb am zuletzt editiert von
                                  #40

                                  Hallo,

                                  Ich weiß nicht mehr ganz genau, ob ich noch was anderes geändert habe.

                                  Ist bei mir mehr so trial and error.

                                  Gruß

                                  Chris

                                  `/* 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 =   'Biotonne';              // 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 = '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; 18/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("45/*/*",/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/pruefekalender();<e=""></kalender.length;>`[/i][/i][/i]
                                  
                                  1 Antwort Letzte Antwort
                                  0
                                  • wendy2702W Online
                                    wendy2702W Online
                                    wendy2702
                                    schrieb am zuletzt editiert von
                                    #41

                                    Funktioniert es denn so?

                                    Gesendet von iPhone mit Tapatalk

                                    Bitte keine Fragen per PN, die gehören ins Forum!

                                    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                    1 Antwort Letzte Antwort
                                    0
                                    • a200A Offline
                                      a200A Offline
                                      a200
                                      schrieb am zuletzt editiert von
                                      #42

                                      hier scheint noch ein Fehler zu stecken.

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

                                      das else setState(idEventState, false); sollte meiner Meinung Raus. Denn wenn du über Mehrere Instanzen gehst, dann kann es sein, dass du oben den Wert auf true setzt und später wieder auf false.

                                      a200

                                      IoBroker auf QNAP TS-451, Raspi und NUC

                                      1 Antwort Letzte Antwort
                                      0
                                      • N Offline
                                        N Offline
                                        nathan1312
                                        schrieb am zuletzt editiert von
                                        #43

                                        So liebe Leute.

                                        Wer noch Probleme mit dem Script hat, dem empfehle ich folgendes auszuprobieren:

                                        `/* 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 =   'RESTMÜ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(suchstring, false, {
                                             type: 'boolean',
                                             def: 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; 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);/break;/}/else/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/<e=""></kalender.length;>`
                                        
                                        Anstelle von
                                        
                                        `~~[code]~~createState(suchstring, false, {
                                             type: 'boolean',
                                             def: false
                                        });[/code]`
                                        
                                        kann auch der längere Ausdruck in dem Script für Sven unter Einbeziehung des strings "Müllwarnung" verwendet werden.
                                        
                                        Ebenso kann der "Umweg" über die Variable "idEventState" verwendet werden.
                                        
                                        Wichtig ist nur folgender Codeteil in dem Script oben:
                                        
                                        `~~[code]~~  break;
                                                        } else setState(suchstring, false);
                                                    } else setState(suchstring, false);[/code]`
                                        
                                        Der Befehl "break" sorgt dafür, dass die Suche nachdem das gewünschte Ereignis gefunden wurde abgebrochen wird. Andernfalls werden weitere Termine im Zeitfenster geprüft und der Status der Meldung wieder fälschlicherweise wieder auf "false" gesetzt.
                                        
                                        Danach muss für beide Fälle, dass das gewünschte Ereignis NICHT gefunden wurde, der Befehl folgen, den Status wieder auf "false" zu setzen, da dieser sonst auch nach Ablauf des Ereignis bei "true" bleibt. (Für den Fall, dass die Variable "idEventState" verwendet wird muss der Ausdruck "suchstring" durch "idEventState" ersetzt werden!)
                                        
                                        Probiert es aus, es funktioniert so.
                                        
                                        Beste Grüße![/i][/i][/i]
                                        
                                        1 Antwort Letzte Antwort
                                        0
                                        • S Offline
                                          S Offline
                                          Sven2013
                                          schrieb am zuletzt editiert von
                                          #44

                                          Hallo Nathan,

                                          vielen Dank für deine Hinweise. Ich habe versucht diese einzubauen, doch leider bringt das keinen Erfolg. Kannst du vielleicht noch einmal über mein aktuell genutztes script schauen? Ich setzte das Script insgesamt 4 Mal ein für jede Tonne einzeln.

                                          `/* 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 =      false;                // 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);/break;/}/else/setstate(suchstring,/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;>`
                                          
                                          Hier noch eine aktuelle Fehlermeldung:
                                          
                                          `~~[code]~~javascript.0	2016-12-26 00:33:05.009	warn	State "Rest" not found
                                          javascript.0	2016-12-26 00:33:05.009	warn	State "Rest" not found
                                          javascript.0	2016-12-26 00:33:05.008	warn	State "Rest" not found
                                          javascript.0	2016-12-26 00:33:05.007	warn	State "Papier" not found
                                          javascript.0	2016-12-26 00:33:05.007	warn	State "Papier" not found
                                          javascript.0	2016-12-26 00:33:05.005	warn	State "Papier" not found
                                          javascript.0	2016-12-26 00:33:05.003	warn	State "Grüne" not found
                                          javascript.0	2016-12-26 00:33:04.999	warn	State "Grüne" not found
                                          javascript.0	2016-12-26 00:33:04.998	warn	State "Grüne" not found
                                          javascript.0	2016-12-26 00:33:04.997	warn	State "Bio" not found
                                          javascript.0	2016-12-26 00:33:04.996	warn	State "Bio" not found
                                          javascript.0	2016-12-26 00:33:04.995	warn	State "Bio" not found[/code]`
                                          
                                          Vielen Dank, Gruß Sven[/i][/i][/i]
                                          
                                          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

                                          644

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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