[Python-ideas] adding a trim convenience function

Tal Einat taleinat at gmail.com
Wed Mar 5 23:59:07 CET 2008


Erick Tryzelaar wrote:
> I find that when I'm normalizing strings, I end up writing this a lot:
>
>  sites = ['www.google.com', 'http://python.org', 'www.yahoo.com']
>  new_sites = []
>  for site in sites:
>   if site.startswith('http://'):
>     site = site[len('http://'):]
>   new_sites.append(site)
>
>  But it'd be much nicer if I could use a convenience function trim that
>  would do this for me, so I could just use a comprehension:
>
>  def ltrim(s, prefix):
>   if s.startswith(prefix):
>     return s[len(prefix):]
>   return s
>
>  sites = ['www.google.com', 'http://python.org', 'www.yahoo.com']
>  sites = [ltrim(site, 'http://') for site in sites]
>
>  Would there be any interest to add this helper function, as well as an
>  "rtrim" and "trim", to the str class?
>

I'm against adding this as a string method, or even a a function in the stdlib.

I've done a lot of text processing with Python and have hardly ever
needed something like this. If you think this would be useful often, a
good way to convince this list is to show some examples of how it
could improve code in the standard library, noting how common they
are.

In general, having a lot of string methods is very harmful because it
makes learning Python a longer and more confusing process.
Furthermore, this functionality is very simple and easy to implement,
I just thought of 3 different ways [1] to implement this function in a
simple, readable one-liner. For these reasons, unless you can show
that this will be very useful very often, I'm against.

- Tal


[1]
ltrim = lambda item, to_trim,: re.sub('^' + to_trim, '', item)
ltrim = lambda item, x: item[0 if not item.startswith(x) else len(x):]
ltrim = lambda item, to_trim: ''.join(item.split(to_trim, 1))



More information about the Python-ideas mailing list