Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Wieder ein RegEx-Problem

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Wieder ein RegEx-Problem

    This topic has been deleted. Only users with topic management privileges can see it.
    • K
      Kamikaze last edited by

      Hallo,

      es ist wieder einmal soweit, ich benötige eure Hilfe.

      Mein Script läuft zwar soweit, jedoch erhalte ich durch diesen Teil beim Beenden bzw. neu starten immer eine Fehlermeldung.

      javascript.0 2017-05-05 19:34:03.217 info Start javascript script.js.Lokal.Ereignisse

      javascript.0 2017-05-05 19:34:03.204 warn unsubscribe: empty name

      javascript.0 2017-05-05 19:34:03.201 info Stop script script.js.Lokal.Ereignisse

      `on({name:/^Anwesenheit\./,change:'any'}, function (obj) {
          var i = 0;
          var element = [
                          ["Anwesenheit.surface",            "Surface ist nicht mehr online"          ,    "Surface ist wieder online"         ],
                          ["Anwesenheit.EchoDot",            "Echo Dot ist nicht mehr online"            ,    "Echo Dot ist wieder online"          ],
                          ["Anwesenheit.BB_Kindle",          "Bärbels Kindle ist nicht mehr online"  ,    "Bärbels Kindle ist wieder online"  ],
                          ["Anwesenheit.Kurt",               "Kurt hat das Haus verlassen"            ,    "Kurt ist wieder zu Hause"          ],
                          ["Anwesenheit.Baerbel",            "Bärbel hat das Haus verlassen"          ,   "Bärbel ist wieder zu Hause"        ],
                          ["Anwesenheit.Dennis",             "Dennis hat das Haus verlassen"          ,   "Dennis ist wieder zu Hause"]
                      ];
      //    log (obj.name , "info");
          if ((obj.newState.val === obj.oldState.val))    {                                    // Zwei Durchgänge gleicher Wert 
              if ((obj.newState.val === 0) || (obj.newState.val === false)) {
                  for (i=0;i<element.length;i++) {/if/(obj.name="=" element[i][0])/setstate/(idsayit,/element[i][1]);/}/else/for/(i="0;i<element.length;i++)" element[i][2]);/});<e=""></element.length;i++)>`
      
      Wer kann mir dabei helfen?[/i][/i][/i][/i]
      
      1 Reply Last reply Reply Quote 0
      • Dutchman
        Dutchman Developer Most Active Administrators last edited by

        @Kamikaze:

        Wer kann mir dabei helfen? `

        muesste````
        on({name:/^Anwesenheit./,change:'any'}, function (obj) {

        Nicht````
        on({id:/^Anwesenheit\./,change:'any'}, function (obj) {
        ````sein ?
        
        also ID anstatt name ? Wuerde auch erklaehren warum er den fehler auspukt "kan nicht subscriben auf name"
        1 Reply Last reply Reply Quote 0
        • K
          Kamikaze last edited by

          Hallo Dutchman,

          das ist meines Erachtens nicht richtig, da meine Objekte wie folgt aussehen:

          und ich deshalb auf den Namen den RegEx anwende.

          Dies sind Systemvariablen von der Homematic CCU2 deshalb kann ich keine passende ID vergeben.

          hm-rega.0								
          	5096	Anwesenheit.Kurt		state	state			false	
          	5097	Anwesenheit.Baerbel	state	state			true	
          	5098	Anwesenheit.Dennis	state	state			true	
          	5099	Anwesenheit.Nutzer	state	state			true	
          	5100	Anwesenheit.list		state	state			55	
          	5101	Anwesenheit.string	state	state			BB_Kindle,Baerbel,surface,Dennis	
          	5285	Anwesenheit.Gast	state	state			false	
          	5638	Anwesenheit.BB_Kindle	state	state			true	
          	5639	Anwesenheit.surface	state	state			true	
          
          

          Die Funktion selbst ist da, d.h. wenn die Variable z.B. 5096 geändert wird, triggert iobroker auf die Abwesenheit von Anwesenheit.Kurt und führt die Aktion aus.

          1 Reply Last reply Reply Quote 0
          • Dutchman
            Dutchman Developer Most Active Administrators last edited by

            @Kamikaze:

            Hallo Dutchman,

            das ist meines Erachtens nicht richtig, da meine Objekte wie folgt aussehen:

            und ich deshalb auf den Namen den RegEx anwende.

            Dies sind Systemvariablen von der Homematic CCU2 deshalb kann ich keine passende ID vergeben.

            hm-rega.0								
            	5096	Anwesenheit.Kurt		state	state			false	
            	5097	Anwesenheit.Baerbel	state	state			true	
            	5098	Anwesenheit.Dennis	state	state			true	
            	5099	Anwesenheit.Nutzer	state	state			true	
            	5100	Anwesenheit.list		state	state			55	
            	5101	Anwesenheit.string	state	state			BB_Kindle,Baerbel,surface,Dennis	
            	5285	Anwesenheit.Gast	state	state			false	
            	5638	Anwesenheit.BB_Kindle	state	state			true	
            	5639	Anwesenheit.surface	state	state			true	
            
            

            Die Funktion selbst ist da, d.h. wenn die Variable z.B. 5096 geändert wird, triggert iobroker auf die Abwesenheit von Anwesenheit.Kurt und führt die Aktion aus. `

            Hmm verstehe ich nicht gans wie du das meinst….

            Der fehler kommt deutlich vom subscribe daher such ich die ursache auch im "on" statement, ich frage bei mir auch states ab innerhalb eines ordners und benutze dafuer:

            on({id: /^javascript\.\d\.domoticz\.Devices\.\d+\.STATE$/ , change: "ne"}, function (obj) {
            

            dieser code trigger auf alle state changes in domoticz.Devices

            1 Reply Last reply Reply Quote 0
            • K
              Kamikaze last edited by

              Tja, das ist ganz einfach:

              In deinem Beispiel über den Objekt-Reiter Spalte ID javascript.0.domoticz …, Spalte Name: javascript.0.domoticz ...

              Bei mir ist ID: hm-rega.0.5096 und der Name: Anwesenheit.Kurt

              Wenn man jetzt auf ID den RegEx anwendet, dann greift bei dir die Auswahl, da ID und Name identisch sind.

              Bei mir ist das nicht der Fall.
              1055_unbenannt.png

              1 Reply Last reply Reply Quote 0
              • Jey Cee
                Jey Cee Developer last edited by

                Dir fehlt die Wildcard.

                So glaub ich: /^Anwesenheit.*/

                Oder so: /^Anwesenheit..*/

                1 Reply Last reply Reply Quote 0
                • Dutchman
                  Dutchman Developer Most Active Administrators last edited by

                  @Kamikaze:

                  Tja, das ist ganz einfach:

                  In deinem Beispiel über den Objekt-Reiter Spalte ID javascript.0.domoticz …, Spalte Name: javascript.0.domoticz ...

                  Bei mir ist ID: hm-rega.0.5096 und der Name: Anwesenheit.Kurt

                  Wenn man jetzt auf ID den RegEx anwendet, dann greift bei dir die Auswahl, da ID und Name identisch sind.

                  Bei mir ist das nicht der Fall. `

                  eh… nein ?

                  979_beispiel.jpg

                  object beispiel:

                  {
                    "common": {
                      "name": "Woonkamer_Raam.STATE",
                      "type": "boolean",
                      "role": "state",
                      "def": false
                    },
                    "native": {},
                    "type": "state",
                    "_id": "javascript.0.domoticz.Devices.2.STATE",
                    "acl": {
                      "object": 1638,
                      "state": 1638
                    }
                  }
                  
                  

                  und sonst doch wildcard wie @kamikaze meinte das sollte es sein 🙂

                  Getestet bei mir und hat selben effect also sollte die wildcard auch bei deinem name die loesung sein 🙂

                  on({id: /^javascript\.\d\.domoticz\.Devices\.\d+\.*/ , change: "ne"}, function (obj) {
                  
                  1 Reply Last reply Reply Quote 0
                  • K
                    Kamikaze last edited by

                    Hier herrscht ja rege Aktivität.

                    Also erster Ansatz mit Wildcard brin gleichen Fehler beim Beenden des Scripts.

                    Zu Dutchman

                    Mein Objekt sieht aber anders aus.
                    1055_unbenannt.png

                    In dem Kreis mit dem blauen Pfeil steht die ID, daher kann ich darauf nicht abfragen.

                    Bei dir steht.
                    1055_unbenannt1.png

                    Ich will nicht ausschließen, dass ich hier etwas total missverstehe, aber wenn ich auf deinen Vorschlag mit ID eingehe, dann löst das Ereignis nicht aus.

                    on({id:/^Anwesenheit..*/,change:'any'}, function (obj) {}

                    Egal ob mit oder ohne Wildcard.

                    Dafür kommt der Fehler nicht mehr.

                    1 Reply Last reply Reply Quote 0
                    • Dutchman
                      Dutchman Developer Most Active Administrators last edited by

                      @Kamikaze:

                      Ich will nicht ausschließen, dass ich hier etwas total missverstehe, aber wenn ich auf deinen Vorschlag mit ID eingehe, dann löst das Ereignis nicht aus.

                      on({id:/^Anwesenheit..*/,change:'any'}, function (obj) {}

                      Egal ob mit oder ohne Wildcard.

                      Dafür kommt der Fehler nicht mehr. `

                      hmm, ok… da ich es nicht leiden kan das sowas nicht geht baue ich mir es jetzt mal nach :).

                      Also entweden in ner halben stunde ne antwoord, oder frustration das es nicht klappt. Oder ihr hoert mich ein par tage nicht dan ist der PC ausm fenster geflogen

                      1 Reply Last reply Reply Quote 0
                      • K
                        Kamikaze last edited by

                        Denn man los. Ich warte gerne, speziell wenn jemand so beherzt an die Sache rangeht.

                        1 Reply Last reply Reply Quote 0
                        • Dutchman
                          Dutchman Developer Most Active Administrators last edited by

                          @Kamikaze:

                          Denn man los. Ich warte gerne, speziell wenn jemand so beherzt an die Sache rangeht. `

                          :mrgreen: achja bin auch blutieger anfaenger mit scripten aber macht spass und man lernt :ugeek:

                          also mit id und Anwesenheid passiert bei mir auch nichts, mit name bekommen ich den selben fehler.

                          Das hier geht:

                          on({id: /^hm-rega.0\.*/ , change: "ne"}, function (obj) {
                          

                          Edit:

                          Geschafft 😄

                          on({name: /Anwesenheit.*/ , change: "ne"}, function (obj) {
                          
                          1 Reply Last reply Reply Quote 0
                          • paul53
                            paul53 last edited by

                            @Jey Cee:

                            Oder so: /^Anwesenheit..*/ `
                            Funktioniert das nicht ?

                            Diese Version schließt mit ein, dass der Name mit "Anwesenheit" beginnt und den Punkt hinter "Anwesenheit".

                            1 Reply Last reply Reply Quote 0
                            • K
                              Kamikaze last edited by

                              Da bin ich wieder.

                              @paul53: Die Funktion ist da, aber die Fehlermeldung beim Beenden auch immer noch.

                              @Dutchman: Zu früh gefreut. Ich erhalte die Meldung immer noch. Auslösen tut er zwar auch, aber beim Beenden immer noch

                              javascript.0	2017-05-05 22:56:06.163	info	Start javascript script.js.Lokal.Skript1
                              javascript.0	2017-05-05 22:56:02.321	warn	unsubscribe: empty name
                              javascript.0	2017-05-05 22:56:02.320	info	Stop script script.js.Lokal.Skript1
                              

                              Folgendes habe ich probiert:

                              on({name:/Anwesenheit.*/ , change: "ne"}, function (obj) { …

                              on({name:/Anwesenheit..*/ , change: "ne"}, function (obj) { ...

                              on({name:/^Anwesenheit..*/ , change: "ne"}, function (obj) { ...

                              Bei allen das Gleiche, Starten und Triggern funktioniert, beim Beenden kommt Fehlermeldung.

                              Das on({id: /^hm-rega.0.*/ , change: "ne"}, function (obj) { ... funktioniert kann ich mir vorstellen, da auch die ID abgefragt wird. Jedoch brauche ich den Namen, da nur dieser über RegEx eindeutig identifizierbar ist.

                              Ich bin ja schon einmal zufrieden, dass du den Fehler auch hast. Somit scheint es entweder ein Verständnisproblem oder ein Prgrammfehler zu sein.

                              Dann hoffe ich, dass ein weiterer Experte sich das einmal ansieht.

                              1 Reply Last reply Reply Quote 0
                              • Dutchman
                                Dutchman Developer Most Active Administrators last edited by

                                @Kamikaze:

                                Ich bin ja schon einmal zufrieden, dass du den Fehler auch hast. Somit scheint es entweder ein Verständnisproblem oder ein Prgrammfehler zu sein.

                                Dann hoffe ich, dass ein weiterer Experte sich das einmal ansieht. `

                                jup, hab es auch ein bischen falsch verstanden 😕 trigger hat je functioniert ging um die fehlermeldung.

                                1 Reply Last reply Reply Quote 0
                                • Jey Cee
                                  Jey Cee Developer last edited by

                                  Ich könnte mir vorstellen das es ein Bug ist.

                                  Die Warnung sagt das er alle am Anfang erstellten subscriptions wieder stoppen/auflösen will.

                                  Vermutlich macht das eine for-schleife die ein Array durch geht. Ein Array mit 4 Elementen fängt bei 0 an und endet mit 3. Der Befehl lenght (Anzahl der Elemente im Array) gibt 4 aus. Wenn dabei die Anzahl der Elemente als Startwert verwendet wird ohne vorher 1 ab zu ziehen fängt er bei element 4 an und hört mit 1 auf. Das bedeutet es wird es wird ein leeres Element, Nr. 4, verwendet.

                                  Daher könnte die Warnmeldungen kommen beim Stoppen des Skripts.

                                  Edit: Beim kurz über fliegen des Adapter codes konnte ich das Ausschließen.

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

                                  Support us

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

                                  523
                                  Online

                                  31.9k
                                  Users

                                  80.1k
                                  Topics

                                  1.3m
                                  Posts

                                  4
                                  15
                                  2059
                                  Loading More Posts
                                  • Oldest to Newest
                                  • Newest to Oldest
                                  • Most Votes
                                  Reply
                                  • Reply as topic
                                  Log in to reply
                                  Community
                                  Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                  The ioBroker Community 2014-2023
                                  logo