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

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

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

我想切换“password2”和“password1”的位置-不知道它们的确切位置,只知道它们紧挨着彼此,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(list)):
    try:
      list[i+1]
    except IndexError:
      continue  
    else:
      list[i],list[i+1] = list[i+1],list[i]

怎么可能比

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

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

简单的Python交换如下所示:

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

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

i = foo.index("password2")
for i in range(len(arr)):
    if l[-1] > l[i]:
        l[-1], l[i] = l[i], l[-1]
        break

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

你可以使用例如:

>>> 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']