Forum: PC-Programmierung regex (pcre) Problem


von Harald M. (transporter08)


Lesenswert?

Hallo ihr Lieben,

ich hänge an einem Problem mit einem regex-Ausdruck.
ich habe folgendes Binaermuster:
1
1-#1111#11

mein regex (pcre) sieht so aus:
1
[1-5]{3}/gm

der Match sieht nur das
1
1-#1111#11
2
   ^^^
wie kann man erreichen, dass er ZUSÄTZLICH auch die
1
1-#1111#11
2
    ^^^
sieht ?

Für Anregungen wäre ich Euch sehr dankbar.

von DPA (Gast)


Lesenswert?

Noch ein Komma dazu vielleicht?
1
[1-5]{3,}

Was soll an dem Binär sein? Und wieso zahlen von 1 bis 5?

von Rolf M. (rmagnus)


Lesenswert?

DPA schrieb:
> Noch ein Komma dazu vielleicht?

Soweit ich das verstehe, will er nicht einen Match, in dem alle 4 
Zeichen stehen, sondern zwei Matches, einmal mit dem ersten bis dritten 
Zeichen und einmal mit dem zweiten bis vierten Zeichen (aus der Reihe 
der Einsen).

: Bearbeitet durch User
von foobar (Gast)


Lesenswert?

1
[1-5](?=[1-5]{2})

Matched eine Ziffer der zwei weitere folgen.

von Ralf D. (doeblitz)


Lesenswert?

Welche Sprache bzw. welche Bindings benutzt du denn?

Normalerweise bekommt man ja immer nur einen Match, wiederholtes Matchen 
setzt üblicherweise nach dem letzten Match auf -> überlöappende Matches 
werden nicht gefunden.

Du müsstest daher für weitere (überlappende) Matches unmittelbar hinter 
Start des letzten Matches aufsetzen. Wie man das macht hängt aber von 
der benutzten Sprache bzw. Binding ab.

von Harald M. (transporter08)


Lesenswert?

Erstmal vielen Dank für alle Eure Anteilnahme und Anregungen.

Ralf D. schrieb:
> Welche Sprache bzw. welche Bindings benutzt du denn?
>
> Normalerweise bekommt man ja immer nur einen Match, wiederholtes Matchen
> setzt üblicherweise nach dem letzten Match auf -> überlöappende Matches
> werden nicht gefunden.
>
> Du müsstest daher für weitere (überlappende) Matches unmittelbar hinter
> Start des letzten Matches aufsetzen. Wie man das macht hängt aber von
> der benutzten Sprache bzw. Binding ab.

Überlappend ist ein sehr gutes Stichwort :)

Genau das brauche ich hier, aber mir ist das in der Form auf der Zunge 
liegen geblieben.

Wie kann ich das hier (pcre = Perl Compatible Regular Expressions) 
umsetzen ?

von Ralf D. (doeblitz)


Lesenswert?

Harald M. schrieb:
[...]
> Überlappend ist ein sehr gutes Stichwort :)
>
> Genau das brauche ich hier, aber mir ist das in der Form auf der Zunge
> liegen geblieben.
>
> Wie kann ich das hier (pcre = Perl Compatible Regular Expressions)
> umsetzen ?

Du musst mehrfach matchen und dabei jeweils den Anfang des Strings 
verschieben: erster Matchvorgang liefert Beginn des erfolgreichen 
Matches bei Position x, du machst den nächsten Matchvorgang beginnend 
bei Position x+1.

Wie du das konkret machen kannst hängt halt von der benutzten Sprache 
bzw. den Bindings ab ...

von Frank L. (Firma: Flk Consulting UG) (flk)


Lesenswert?

Hallo,

versuch es mal damit.

(?=(1{3}))

Der Ausdruck findet alle Gruppe zu je 3 "111".

Du kannst es unter https://regex101.com/ testen

Gruß
Frank

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.