I have an application which needs some verifications for some fields. One of them is for a last name which can be composed of 2 words. In my regex, I have to accept these spaces so I tried a lot of things but I did'nt find any solution.
Here is my regex :
parsing "^[a-zA-Zàéèêçñ\s][a-zA-Zàéèêçñ-\s]+$" - Cannot include class \s in character range.
- denotes a character range, just as you use
A-Z to describe any character between A and Z. Your regex uses
~n-\s which the engine tries to interpret as any character between ~n and \s -- and then notices, that
\s doesn't make a whole lot of sense there, because
\s itself is only an abbreviation for any whitespace character.
That's where the error comes from.
To get rid of this, you should always put
- at the end of your character class, if you want to include the
- literal character:
This way, the engine knows that
\s- is not a character range, but the two characters
The other way is to escape the
So now the engine interprets
~n\-\s not as a character range, but as any of the characters
\s. Personally, though I always try to avoid escaping as often as possible, because IMHO it clutters up and needlessly stretches the expression in length.