subixonfire
subixonfire

Reputation: 303

Swap values in a tuple/list inside a list in python?

I have a list of tuples like this:

[('foo','bar'),('foo1','bar1'),('foofoo','barbar')]

What is the fastest way in python (running on a very low cpu/ram machine) to swap values like this...

[('bar','foo'),('bar1','foo1'),('barbar','foofoo')]

I am currently using:

for x in mylist:
    self.my_new_list.append(((x[1]),(x[0])))

Is there a better or faster way???

Upvotes: 20

Views: 35676

Answers (5)

Elliot Cameron
Elliot Cameron

Reputation: 5297

You can use reversed like this:

tuple(reversed((1, 2)) == (2, 1)

To apply it to a list, you can use map or a list/generator comprehension:

map(tuple, map(reversed, tuples))     # map
[tuple(reversed(x)) for x in tuples]  # list comprehension
(tuple(reversed(x)) for x in tuples)  # generator comprehension

If you're interested primarily in runtime speed, I can only recommend that you profile the various approaches and pick the fastest.

Upvotes: 14

Timur Shtatland
Timur Shtatland

Reputation: 12347

To modify the current list in-place, the most efficient way is:

my_list[:] = [(y, x)  for x, y in my_list]

It is assigning to the list slice, which covers the entire list, without creating an extra duplicate of the list in memory. See also this answer.

Upvotes: 0

Marco
Marco

Reputation: 1575

Using a list comprehension I find more elegant and understandable to use separate variables instead of indices for a single variable as in the solution provided by @iabdalkader:

[(b, a) for a, b in mylist]

Upvotes: 3

vperezb
vperezb

Reputation: 403

A fancy way:

[t[::-1] for t in mylist]

Upvotes: 5

iabdalkader
iabdalkader

Reputation: 17312

You could use map:

map (lambda t: (t[1], t[0]), mylist)

Or list comprehension:

[(t[1], t[0]) for t in mylist]

List comprehensions are preferred and supposedly much faster than map when lambda is needed, however note that list comprehension has a strict evaluation, that is it will be evaluated as soon as it gets bound to variable, if you're worried about memory consumption use a generator instead:

g = ((t[1], t[0]) for t in mylist)
#call when you need a value
g.next()

There are some more details here: Python List Comprehension Vs. Map

Upvotes: 22

Related Questions