Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.lang.python > #5019
| References | <mailman.1289.1304771900.9059.python-list@python.org> <c1f15442-524b-406e-a074-e1a309bc3ec0@s16g2000prf.googlegroups.com> |
|---|---|
| From | Ian Kelly <ian.g.kelly@gmail.com> |
| Date | 2011-05-09 14:07 -0600 |
| Subject | Re: Custom string joining |
| Newsgroups | comp.lang.python |
| Message-ID | <mailman.1350.1304971691.9059.python-list@python.org> (permalink) |
On Mon, May 9, 2011 at 1:26 PM, Martineau <ggrp2.20.martineau@dfgh.net> wrote:
> Instead of join() here's a function that does something similar to
> what the string join() method does. The first argument can be a list
> of any type of objects and the second separator argument can likewise
> be any type. The result is list of the various objects. (The example
> usage just uses a list of string objects and separator to illustrate
> what it does.)
>
> def tween(seq, sep):
> return reduce(lambda r,v: r+[sep,v], seq[1:], seq[:1])
>
> lst = ['a','b','c','d','e']
>
> print tween(lst, '|')
> print ''.join(tween(lst, '|'))
>
> Output:
>
> ['a', '|', 'b', '|', 'c', '|', 'd', '|', 'e']
> a|b|c|d|e
>
>
> It could be made a little more memory efficient by applying the
> itertools module's islice() generator to the first 'seq' argument
> passed to reduce():
>
> def tween(seq, sep):
> return reduce(lambda r,v: r+[sep,v], itertools.islice(seq,1,None),
> seq[:1])
This version accepts any iterable, not just a list:
def tween(seq, sep):
it = iter(seq)
try:
first = it.next()
except StopIteration:
return []
return reduce(lambda r, v: r + [sep, v], it, [first])
A further efficiency improvement would be to do the list concatenation
in place to avoid generating O(n) intermediate copies:
def tween(seq, sep):
it = iter(seq)
try:
first = it.next()
except StopIteration:
return []
def add_sep(r, v):
r += [sep, v]
return r
return reduce(add_sep, it, [first])
Back to comp.lang.python | Previous | Next — Previous in thread | Find similar | Unroll thread
Custom string joining Claudiu Popa <cpopa@bitdefender.com> - 2011-05-07 15:31 +0300
Re: Custom string joining Martineau <ggrp2.20.martineau@dfgh.net> - 2011-05-09 12:26 -0700
Re: Custom string joining Ian Kelly <ian.g.kelly@gmail.com> - 2011-05-09 14:07 -0600
csiph-web