On 2022-08-16 22:14, Barry Scott wrote:
> On 16 Aug 2022, at 21:24, MRAB <pyt...@mrabarnett.plus.com> wrote:
> > Other regex implementations have escape sequences for horizontal whitespace (`\h` and `\H`) and vertical whitespace (`\v` and `\V`). > > The regex module already supports `\h`, but I can't use `\v` because it represents `\0x0b', as it does in the re module.

You seem to be mixing the use \ as the escape for strings and the \ that re 
uses.
Is it the behaviour that '\<unknown>' becomes '\\<unknown>' that means this is 
a breaking change?

Won't this work?
```
re.compile('\v:\\v')
# which is the same as
re.compile(r'\x0b:\v')
```

Some languages, e.g. Perl, have a dedicated syntax for writing regexes, and they take `\n` (a backslash followed by 'n') to mean "match a newline".

Other languages, including Python, use string literals and can contain an actual newline, but they also take `\n` (a backslash followed by 'n') to mean "match a newline".

Thus:

>>> print(re.match('\n', '\n')) # Literal newline.
<re.Match object; span=(0, 1), match='\n'>
>>> print(re.match('\\n', '\n')) # `\n` sequence.
<re.Match object; span=(0, 1), match='\n'>

On the other hand:

>>> print(re.match('\b', '\b')) # Literal backspace.
<re.Match object; span=(0, 1), match='\x08'>
>>> print(re.match('\\b', '\b')) # `\b` sequence, which means a word boundary.
None
>>>

The problem is that the re and regex modules already have the `\v` (a backslash followed by 'v') sequence to mean "match the '\v' character", so:

re.compile('\v')

and:

re.compile('\\v')

mean exactly the same.

> Now that someone has asked for it, I'm trying to find a nice way of adding 
it, and I'm currently thinking that maybe I could use `\y` and `\Y` instead as 
they look a little like `\v` and `\V`, and, also, vertical whitespace is sort-of 
in the y-direction.
> > As far as I can tell, only ProgressSQL uses them, and, even then, it's for what everyone else writes as `\b` and `\B`. > > I want the regex module to remain compatible with the re module, in case they get added there sometime in the future. > > Opinions?
_______________________________________________
Python-Dev mailing list -- python-dev@python.org
To unsubscribe send an email to python-dev-le...@python.org
https://mail.python.org/mailman3/lists/python-dev.python.org/
Message archived at 
https://mail.python.org/archives/list/python-dev@python.org/message/KHI74Y2JJRYFRBGGNJUSL7RZCBAI7IAN/
Code of Conduct: http://python.org/psf/codeofconduct/

Reply via email to