Message367306
The usage of difflib.SequenceMatcher.find_longest_match could be simplified for the most common use case (finding the longest match between the entirety of the two strings) by taking default args.
At the moment you have to do:
>>> from difflib import SequenceMatcher
>>> a, b = 'foo bar', 'foo baz'
>>> s = SequenceMatcher(a=a, b=b)
>>> s.find_longest_match(0, len(a), 0, len(b))
Match(a=0, b=0, size=6)
but with default args the final line could be simplified to just:
>>> s.find_longest_match()
Match(a=0, b=0, size=6)
which seems to be much cleaned and more readable.
I'd suggest updating the code so that the function signature becomes:
find_longest_match(alo=None, ahi=None, blo=None, bhi=None)
which is consistent with the current docstring of "Find longest matching block in a[alo:ahi] and b[blo:bhi]." as `a[None:None]` is the whole of `a`.
I think this would only be a minor code change, and if it is something that would be useful I'd be happy to have a go at a PR. |
|
Date |
User |
Action |
Args |
2020-04-26 14:15:58 | Lewis Ball | set | recipients:
+ Lewis Ball |
2020-04-26 14:15:58 | Lewis Ball | set | messageid: <1587910558.56.0.865649390619.issue40394@roundup.psfhosted.org> |
2020-04-26 14:15:58 | Lewis Ball | link | issue40394 messages |
2020-04-26 14:15:58 | Lewis Ball | create | |
|