python 的list 数据类型

List是python的基本数据类型之一

注意list[2]表示访问列表第三个元素,list[-2]表示访问的是列表倒数第二个元素

list[1:]表示从第二个列表元素开始截取列表

list1=[1,2,3,4]
list2=["cnm","fuck you","nmsl"]

print(list1)#输出[1,2,3,4]
print(list1[0])#输出1

print(list1[1:5])#[2,3,4]
print(list1[0:1])#[1]
print(list1[0:2])#[1,2]
print(list1[0:4])#[1,2,3,4]

print(list2[1])#fuck you

更新列表

list=[]
list.append("ss")
list.append("tt")
print(list)

删除列表元素

list=[1,2,3,4,5]
print(list)
del(list[2])
print(list)

列表的脚本操作

list1=[1,2,3]
list2=[4,5,6]
list1=list1+list2#列表合并
print(list1)

list1=list1*2#列表复制
print(list1)

if(3in(list1)):#列表元素判断是否在内
    print("Yes")
else:
    print("No")

for x in list1:#遍历列表
    print(x)

常用成员函数

len(list)返回列表元素个数

list.count(obj)统计某个元素在列表中出现的次数

list.index(obj)从列表中找出某个值第一个匹配项的索引位置

list.insert(index, obj) 将元素插入列表的指定位置

list=[5,6,7,8,9]
list.insert(3,1)
print(list)#[5, 6, 7, 1, 8, 9]

list.pop([index=-1])移除列表中的一个元素(默认最后一个元素),并且返回该元素的值

list.reverse()反向列表中元素

list.remove(obj)移除列表中某个值的第一个匹配项

list.sort(cmp=None, key=None, reverse=False)对原列表进行排序

  其中reverse=False为默认升序,True为降序

list=['a','e','i','o','u']
list.sort(reverse=False)
print(list)#['a', 'e', 'i', 'o', 'u']
list.sort(reverse=True)
print(list)#['u', 'o', 'i', 'e', 'a']

  key表示用来进行排序比较的元素。

  这个元素取自python的可迭代对象(python中的可迭代对象指的是列表、元组、字典、字符串)。指定可迭代对象

的这个元素来进行排序。

def second(x):#取该元组的第二个元素进行排序
    return x[1]
tup=[(1,1),(1,3),(1,4),(1,2)]
tup.sort(key=second)
print(tup)#[(1, 1), (1, 2), (1, 3), (1, 4)]


#列表按照其中每一个值的绝对值排序
l1 = [1,3,5,-2,-4,-6]
l2 = sorted(l1,key=abs)
print(l1)#[1, 3, 5, -2, -4, -6]
print(l2)#[1, -2, 3, -4, 5, -6]

#sorted是可以保存原有列表顺序的排序方式


#列表按照每一个元素的len排序
l = [[1,2],[3,4,5,6],(7,),'123']
print(sorted(l,key=len))#[(7,), [1, 2], '123', [3, 4, 5, 6]]

不难发现,就是对于列表中的每一个元素,进行key()操作之后,再进行排序。编译的时候应该是这么处理的吧。

貌似python3.x中取消了cmp参数?

那么如何实现return A.x<B.x?true:A.y<B.y 这样的多重比较(自定义排序)呢?

可以如下实现

# 如果逻辑上认为 a < b ,返回 -1
# 如果逻辑上认为 a > b , 返回 1
# 如果逻辑上认为 a == b, 返回 0 
import functools
def cmp(A,B):
    if(A[0]<B[0]):
        return -1
    elif(A[0]==B[0]):
        if(A[1]<B[1]):
            return -1
        elif(A[1]==B[1]):
            return 0
        else: 
            return 1
    else:
        return 1

tup=[(7,1),(6,2),(6,1),(8,4)]
tup.sort(key=functools.cmp_to_key(cmp))
print(tup)#[(6, 1), (6, 2), (7, 1), (8, 4)]