最新消息:阿里云双12优惠,史上最低折扣。

python教程—列表删除元素

服务器租用 aliyun 189浏览

python教程—列表转字符串

应用Python列表十分重要,列表转字符串、字典这些小知识你都会了嘛?多维元组转换列表这些“惊天地泣鬼神”的操作你掌握的咋样?

Python现今十分火热,对于其列表应用来说也是十分重要的一环,列表中我们怎么删除元素?怎么检索重复元素并删除这些你都会吗?本次小睿就跟大家探讨一下这个问题。

python 3.x中列表中元素删除delremovepop详解

使用del删除指定位置元素

del是python语句,而不是列表方法,无法通过list来调用。使用del可以删除一个元素,当元素删除之后,位于它后面的元素会自动移动填补空出来的位置。

example:A列表

                            del A[位置]

# usr/bin/python

# _*_ coding:utf-8 _*_

= [‘a’,‘b’,‘c’]

del a[0]  #指定删除0位的元素

print(a)

输出为:[‘b’, ‘c’]

使用remove()删除指定值

如果不确定或不关心元素在列表中的位置,可以使用remove()根据指定的值来删除元素。

example: 列表A

                            A.remove(‘str’)

# usr/bin/python

# _*_ coding:utf-8 _*_

= [‘a’,‘b’,‘c’]

a.remove(‘b’) #删除指定元素

print(a)

输出为:[‘a’, ‘c’]

使用pop()获取并删除指定位置元素

使用pop()同样可以获取列表中指定位置的元素,但在获取完成之后,该元素会自动被删除。如果为pop(off)指定了偏移量,它会返回偏移量对应位置的元素。如果不指定,则默认使用1。因此pop(0)将返回头元素,而pop()或pop(-1)则会返回列表的尾元素。

example: 列表A

# usr/bin/python

# _*_ coding:utf-8 _*_

= [‘a’,‘b’,‘c’]

= [‘d’,‘e’,‘f’]

# pop的命令,其有返回值,可赋值带出

= a.pop() #默认删除-1位置元素’c’,并将删除元素返回值赋值

= b.pop(0) #删除0位元素’d’,并将删除元素返回值赋值

print(a,b,c,d)

返回值:[‘a’, ‘b’] [‘e’, ‘f’] c d

python列表删除重复元素的三种方法

给定一个列表,要求删除列表中重复元素。

listA = [‘python’,‘语’,‘言’,‘是’,‘一’,‘门’,‘动’,‘态’,‘语’,‘言’]

方法1,对列表调用排序,从末尾依次比较相邻两个元素,遇重复元素则删除,否则指针左移一位重复上述过程:

def deleteDuplicatedElementFromList(list):

        list.sort();

        print(“sorted list:%s” % list)

        length = len(list)

        lastItem = list[length  1]

        for i in range(length  2,-1,-1):

                currentItem = list[i]

                if currentItem == lastItem:

                        list.remove(currentItem)

                else:

                        lastItem = currentItem

        return list

方法2,设一临时列表保存结果,从头遍历原列表,如临时列表中没有当前元素则追加:

def deleteDuplicatedElementFromList2(list):

        resultList = []

        for item in list:

                if not item in resultList:

                        resultList.append(item)

        return resultList

方法3,利用python中集合元素惟一性特点,将列表转为集合,将转为列表返回:

def deleteDuplicatedElementFromList3(listA):

        #return list(set(listA))

        return sorted(set(listA), key = listA.index)

执行结果:

print(deleteDuplicatedElementFromList(listA))        

#sorted list:[‘python’, ‘一’, ‘动’, ‘态’, ‘是’, ‘言’, ‘言’, ‘语’, ‘语’, ‘门’]

#[‘python’, ‘一’, ‘动’, ‘态’, ‘是’, ‘言’, ‘语’, ‘门’]

print(deleteDuplicatedElementFromList2(listA))        

#[‘python’, ‘语’, ‘言’, ‘是’, ‘一’, ‘门’, ‘动’, ‘态’]

print(deleteDuplicatedElementFromList3(listA))        

#[‘python’, ‘语’, ‘言’, ‘是’, ‘一’, ‘门’, ‘动’, ‘态’]

分析:

方法1,逻辑复杂,临时变量保存值消耗内存,返回结果破坏了原列表顺序,效率最差

方法2,直接调用append方法原处修改列表,逻辑清晰,效率次之

方法3,极度简洁,使用python原生方法效率最高

转载请注明:小猪云服务器租用推荐 » python教程—列表删除元素