我还没能在网上找到一个很好的解决这个问题的方法(可能是因为switch, position, list和Python都是重载的单词)。

其实很简单——我有这样一个列表:

['title', 'email', 'password2', 'password1', 'first_name', 'last_name', 'next', 'newsletter']

我想切换“password2”和“password1”的位置-不知道它们的确切位置,只知道它们紧挨着彼此,password2是第一个。

我已经完成了一些相当冗长的列表下标,但我想知道是否有可能想出一些更优雅的东西?


当前回答

怎么可能比

tmp = my_list[indexOfPwd2]
my_list[indexOfPwd2] = my_list[indexOfPwd2 + 1]
my_list[indexOfPwd2 + 1] = tmp

这只是一个使用临时存储的普通交换。

其他回答

i = ['title', 'email', 'password2', 'password1', 'first_name', 
     'last_name', 'next', 'newsletter']
a, b = i.index('password2'), i.index('password1')
i[b], i[a] = i[a], i[b]

我不是python方面的专家,但你可以试试: 说

i = (1,2)

res = lambda i: (i[1],i[0])
print 'res(1, 2) = {0}'.format(res(1, 2)) 

以上给出的o/p为:

res(1, 2) = (2,1)

简单的Python交换如下所示:

foo[i], foo[j] = foo[j], foo[i]

现在你所需要做的就是计算i是多少,这可以通过index很容易地完成:

i = foo.index("password2")

怎么可能比

tmp = my_list[indexOfPwd2]
my_list[indexOfPwd2] = my_list[indexOfPwd2 + 1]
my_list[indexOfPwd2 + 1] = tmp

这只是一个使用临时存储的普通交换。

你可以使用例如:

>>> test_list = ['title', 'email', 'password2', 'password1', 'first_name',
                 'last_name', 'next', 'newsletter']
>>> reorder_func = lambda x: x.insert(x.index('password2'),  x.pop(x.index('password2')+1))
>>> reorder_func(test_list)
>>> test_list
... ['title', 'email', 'password1', 'password2', 'first_name', 'last_name', 'next', 'newsletter']