Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. Adapter - Parser (regEx)

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Adapter - Parser (regEx)

    This topic has been deleted. Only users with topic management privileges can see it.
    • Homoran
      Homoran Global Moderator Administrators @Qlink last edited by Homoran

      @Qlink sagte in Adapter - Parser (regEx):

      habe ich hier einen Denkfehler ?

      Ja!

      Das Ergebnis ist die Group (grün)

      der full match (blau) ist alles was du zur identifizierung dieser Group verwendest

      1 Reply Last reply Reply Quote 0
      • Q
        Qlink last edited by

        ahhh okay und im parser Adapter passiert erst die unterscheidung welchen Wert über NUM !
        Ich glaub jetzt hab ichs 🙂

        Ich werds mal so versuchen anzulegen und schaue wie es sich verhält.

        Vielen Dank für die Hilfe!

        Beste Grüße

        Homoran 1 Reply Last reply Reply Quote 0
        • Diginix
          Diginix @Qlink last edited by Diginix

          @Qlink Mein zweiter Vorschlag war ja auch für den Parser. Hab ja geschrieben dass der Adapter keinen Zeilenumbruch braucht.
          Um mit regex101 wirklich den regex für den Adapter erarbeiten zu können, muss man die Quell Daten "minified" machen. Also alle Einrückungen und Zeilenumbrüche entfernen.
          Der Rest wurde hier glaube ausreichend erklärt.

          1 Reply Last reply Reply Quote 0
          • Homoran
            Homoran Global Moderator Administrators @Qlink last edited by

            @Qlink sagte in Adapter - Parser (regEx):

            im parser Adapter passiert erst die unterscheidung welchen Wert über NUM !

            Ja!

            Entweder musst du für jeden Fall ein eindeutiges RegEx bauen, so dass es nur ein match gibt, oder du nimmst ein möglichst universelles (aber Achtung, da sollte kein Mist bei rauskommen) und filterst dann die z.B.21 matches über die Num

            Diginix 1 Reply Last reply Reply Quote 0
            • Diginix
              Diginix @Homoran last edited by

              @Homoran Ich bevorzuge eindeutige Matches so es denn unique Werte gibt mit denen das möglich ist. Wenn man mehrere Werte aus einer Quelle will, muss man so oder so mehrere Objekte mit jeweils einem RegEx erstellen. Man kann natürlich bei z.B. 3 Werten und einem universellen RegEx mit 3 Klammerpaaren dann mit Num 0-2 arbeiten, aber ich hab eben lieber 3 verschiedene RegEx die exakt nur da matchen wo einer der 3 Werte existiert.
              Je nach Quelldaten kann es aber sein dass man Num braucht.

              Homoran 1 Reply Last reply Reply Quote 0
              • Homoran
                Homoran Global Moderator Administrators @Diginix last edited by

                @Diginix
                ich eigentlich auch.

                Nur für Einsteiger mit dem Parser-Adapter kann es einfacher sein, den RegEx zu kopieren und die num einzustellen

                1 Reply Last reply Reply Quote 0
                • Q
                  Qlink last edited by

                  Ich habe jetzt soweit alle Werte.

                  Einzig die geschätzte Laufzeit meiner USV ärgert mich etwas. Ich würde gerne 1 oder 2 Nachkommastellen ebenfalls auslesen, bekomme aber nur Stellen vor dem Komma:

                  mit

                  
                  "Estimated Runtime"[^\:]+:\s\"(\d+)
                  
                   {
                      "SensorApp": "HWiNFO",
                      "SensorClass": "UPS",
                      "SensorName": "Estimated Runtime",
                      "SensorValue": "51,6833333333333",
                      "SensorUnit": "min",
                      "SensorUpdateTime": 1559130047
                    },
                  

                  regex.PNG

                  Homoran 1 Reply Last reply Reply Quote 0
                  • Homoran
                    Homoran Global Moderator Administrators @Qlink last edited by

                    @Qlink
                    Die zahl beinhaltet ein komma.

                    Versuch mal als typ "zahl mit komma"

                    1 Reply Last reply Reply Quote 0
                    • Q
                      Qlink last edited by

                      Nummer mit Komma ist im Parser Adapter ausgewählt:

                      parser2.PNG

                      Diginix 1 Reply Last reply Reply Quote 0
                      • Diginix
                        Diginix @Qlink last edited by

                        @Qlink \d matcht nur bei Ziffern. Gebrochene Zahlen enthalten aber Ziffern plus Dezimaltrennzeichen. Auch wenn dieser ein Punkt ist, würde \d nicht matchen. Alle Trennzeichen müssen explizit mit ins regex.

                        So sollte es funktionieren:

                        "Estimated Runtime"[^\:]+:\s\"(\d+,\d+)
                        
                        1 Reply Last reply Reply Quote 2
                        • Q
                          Qlink last edited by

                          Super, danke so klappts auch mit den Nachkommastellen ! 🙂

                          Beste Grüße

                          1 Reply Last reply Reply Quote 0
                          • P
                            PatrickFro last edited by

                            Hallo zusammen,

                            ich komme mit dem Parser nicht zurecht. Ich versuche von der Seite https://abfahrten.hvv.de/75870033-9dd4-41c0-81bb-903c93fdc819 Bus-Nummer, Richtung und Abfahrzeit auszulesen. Ich habe dunkle Views erstellt, da passt die weiße Farbe einfach nicht rein. Leider schaffe ich jedoch nicht, mit dem Parser etwas auszulesen. Kann mir dabei jemand helfen?

                            Danke schon vorab!

                            OliverIO 1 Reply Last reply Reply Quote 0
                            • Diginix
                              Diginix last edited by

                              So wie es aussieht werden die Werte per Javascript in der Seite gesetzt. Ich weiß nicht ob der Parser das erst noch interpretiert oder ob der nur mit statischem html umgehen kann.

                              1 Reply Last reply Reply Quote 0
                              • P
                                PatrickFro last edited by

                                Schade... Gibt es denn eine andere Möglichkeit die Daten auszulesen? Oder zumindest die Farben der eingebundenen Webseite zu invertieren?

                                1 Reply Last reply Reply Quote 0
                                • H
                                  hannoi last edited by

                                  Kurze Verständnis Frage, ich parse auf der clever-tanken Seite einen Super Plus Wert z.B. Tanke

                                  Mit dem RegEx

                                  (?:4">)(\d+.\d.)
                                  

                                  bekomme ich auch über die regex101 Seite einen entsprechenden Match der auch wunderbar passt. Wenn ich mir nun den erzeugten Datenpunkt anschaue, finde ich dort nur den Wert ohne Punkt angezeigt:
                                  Bildschirmfoto 2019-06-12 um 11.36.49.png

                                  Ansonsten steht die Regel auf Rolle "Wert" und der Typ ist "Nummer mit Komma", wo hab ich den Denkfehler?

                                  Danke für Hinweise.

                                  Homoran 2 Replies Last reply Reply Quote 0
                                  • Homoran
                                    Homoran Global Moderator Administrators @hannoi last edited by

                                    @hannoi sagte in Adapter - Parser (regEx):

                                    der Typ ist "Nummer mit Komma", wo hab ich den Denkfehler?

                                    Wo ist das Komma?

                                    1 Reply Last reply Reply Quote 0
                                    • H
                                      hannoi last edited by

                                      Genau das Komma suche ich in den Objekten 😕
                                      In den Parser Settings habe ich es entsprechend als Typ "Nummer mit Komma" deklariert...

                                      Homoran H 2 Replies Last reply Reply Quote 0
                                      • Homoran
                                        Homoran Global Moderator Administrators @hannoi last edited by

                                        @hannoi sagte in Adapter - Parser (regEx):

                                        Genau das Komma suche ich in den Objekten

                                        Aber du hast doch auch kein Komma im Match, oder?

                                        1 Reply Last reply Reply Quote 0
                                        • H
                                          hannoi @hannoi last edited by

                                          Hier noch der Link mit dem Quellcode und dem Regex

                                          1 Reply Last reply Reply Quote 0
                                          • Homoran
                                            Homoran Global Moderator Administrators @hannoi last edited by

                                            @hannoi sagte in Adapter - Parser (regEx):

                                            finde ich dort nur den Wert ohne Punkt angezeigt:

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            797
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            43
                                            268
                                            99709
                                            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