I have the following kind of string "sometext1 §§ 12 Abs. 5, 13a, 14 Satz 1 Nr. 3, 9, 8 sometext2". I want to find a §§ substring and all consecutive occurrences of Abs., und, Satz and Nr. as well as digits with a single character like 13a.
Examples:
"Die Anzahl der §§ 12 Abs. 5, 13a, 14 Satz 1 und 8 kann variieren. Für die §§ 15a, 18 Abs. 5, 21 und 23 Satz 3 trifft dies nicht zu.
Here I want to get 12 Abs. 5, 13a, 14 Satz 1 und 8 and 15a, 18 Abs. 5, 21 und 23 Satz 3.
I used the following regex 'r'§§ (.*)? ^(?!Satz|Abs.|Nr.|\d [a-z]| |,)'.
CodePudding user response:
You can use
§§\s*((?:Satz|Abs\.|Nr\.|\d [a-z]?|und|[\s,]) )(?<=\w)
See the regex demo. Details:
§§- a literal text\s*- zero or more whitespaces((?:Satz|Abs\.|Nr\.|\d [a-z]?|und|[\s,]) )- Group 1 capturing one or more occurrences ofSatz,Abs.,Nr., one or more digits optionally followed by a lowercase ASCII letter,und, whitespace or comma.(?<=\w)- the char immediately on the left must be a word char.
