用sort()方法对列表元素进行排序
a = [2,5,3,2,5,7,8,5,3]
a.sort() # 注意,sort()方法是没有返回值的,print(a.sort())会发现打印出来的是None
# 可用reverse指定排序方式,reverse=True 降序,reverse=False 升序(默认)
print(a)
# 输出结果:
# [2, 2, 3, 3, 5, 5, 5, 7, 8]
如果是多维列表,那个按照什么排序的规则呢?
def gz(value):
return value[1]
a = [(4, 3), (2, 4), (6, 1), (1, 3)]
a.sort(key=gz)
print(a)
# 输出结果:
# [(6, 1), (4, 3), (1, 3), (2, 4)]
如果需要只返回排序结果不改变原数据,那么可以用sorted()方法
a = [2,5,3,2,5,7,8,5,3]
b = sorted(a) # 注意sort()是列表的一个调用方法,而sorted()独立的,这个不要用错
# sorted(iterable, key=None, reverse=False)
print(a)
print(b)
# 输出结果:
# [2, 5, 3, 2, 5, 7, 8, 5, 3]
# [2, 2, 3, 3, 5, 5, 5, 7, 8]
我想倒着输出列表里面的元素该怎么办呢?
a = [2,5,3,2,5,7,8,5,3]
a.reverse() # 如果想恢复,再调用一次,负负得正
print(a)
# 输出结果:
# [3, 5, 8, 7, 5, 2, 3, 5, 2]
如何快速去除列表中的重复项?
a = [2,5,3,2,5,7,8,5,3]
a = set(a) # 调用set方法,可以创建一个无序不重复的元素集,用这个方法的缺点是会破坏原有的顺序
# 注意,这里处理的对象是元素集,也就是说元组也是适用的
print(a)
# 输出结果:
# {2, 3, 5, 7, 8}
想要不破坏原有顺序的情况下去重,可以这么写
a = [2,6,4,6,4,2,1,6,5]
b = sorted(set(a),key=a.index)
print(b)
# 输出结果:
# [2, 6, 4, 1, 5]
当我们想要移除一个元素,并且最后一次使用它,该怎么办呢?
a = [2,6,4,6,4,2,1,6,5]
print(a.pop(1))
print(a)
# 输出结果:
# 6
# [2, 4, 6, 4, 2, 1, 6, 5]
现在有三个列表,一个列表保存名字,一个保存班级,一个保存成绩,怎么对他们三个列表元素进行配对打包呢?
a = ['张三','李四','王五']
b = ['1班','3班','1班']
c = [88,93,85]
print(list(zip(a,b,c)))
d = [('ff', '1班', 34), ('李四', '1班', 93), ('王五', '6班', 85)]
a,b,c = zip(*d) # 反之,也可以解压
print(a,b,c)
# 输出结果:
# [('张三', '1班', 88), ('李四', '3班', 93), ('王五', '1班', 85)]
# ('ff', '李四', '王五') ('1班', '1班', '6班') (34, 93, 85)
如果我想查找某个特定元素的序号,但是这个特定元素有多个,这个该怎么解决呢?
a = [2,3,4,3,5,3]
print(a.index(3))
print(list(enumerate(a))) # enumerate()方法可以将一个可遍历的数据对象组合它的下标序号
print([i for i,x in enumerate(a) if x==3]) # 遍历这个对象,每次序号给i,数据给x
# 如果x为我们需要的数据,那么就输出序号i
# 输出结果:
# 1
# [(0, 2), (1, 3), (2, 4), (3, 3), (4, 5), (5, 3)]
# [1, 3, 5]