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

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

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

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

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


当前回答

我不是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")

你可以使用例如:

>>> 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']
for i in range(len(arr)):
    if l[-1] > l[i]:
        l[-1], l[i] = l[i], l[-1]
        break

结果是,如果最后一个元素大于位置I的元素,那么它们都会交换。

我不是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)

怎么可能比

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

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