regex negative lookbehind assertion not working correctly?

andrew cooke andrew at acooke.org
Tue Mar 31 11:52:20 EDT 2009


it is working - it's making the final "8" not be matched.

don't you want lookahead rather than lookbehind?  or force an end of string?

andrew



Gabriel Rossetti wrote:
> Hello everyone,
>
> I am trying to write a regex pattern to match an ID in a URL only if it
> is not a given ID. Here's an example, the ID not to match is
> "14522XXX98", if my URL is "/profile.php?id=14522XXX99" I want it to
> match and if it's "/profile.php?id=14522XXX98" I want it not to. I tried
> this:
>
>  >>> re.search(r"/profile.php\?id=(\d+)(?<!14522XXX98)",
> "/profile.php?id=14522XXX98").groups()
> ('14522XXX9',)
>
> which should not match, but it does, then I tried this :
>
>  >>> re.search(r"/profile.php\?id=(\d+)(?<!14522XXX98)",
> "/profile.php?id=14522XXX99").groups()
> ('14522XXX99',)
>
> which should match and it does. I then tried uring /positive lookbehind
> assertion/ instead and it does this :
>
>  >>> re.search(r"/profile.php\?id=(\d+)(?<=14522XXX98)",
> "/profile.php?id=14522XXX98").groups()
> ('14522XXX98',)
>
> which matches as it should and then I tried this :
>
>  >>> re.search(r"/profile.php\?id=(\d+)(?<=14522XXX98)",
> "/profile.php?id=14522XXX99").groups()
> Traceback (most recent call last):
>   File "<stdin>", line 1, in <module>
> AttributeError: 'NoneType' object has no attribute 'groups'
>
> which doesn't match as it should. Could someone please explain why the
> negative lookbehind assertion is not working as I understand it? Also,
> notice how the last digit of the first expression is not matched, I get
> ('14522XXX9',) instead of ('14522XXX98',), why? It does on the others....
>
> Thank you,
> Gabriel
> --
> http://mail.python.org/mailman/listinfo/python-list
>
>





More information about the Python-list mailing list