python3基础篇——列表的高级用法

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

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值