概念

列表:有序的,可变的,元素集合

因为列表和字符串都是序列类型,所以很多操作和字符串很相似

但是注意:列表是可变类型,字符串是不可变类型

定义

基本定义

定义方法:[ 元素1, 元素2, ...... ]

列表中的元素是任意的,写什么都可以,也可以是另一个列表

可以定义一个空列表:[]

列表生成式

range(stop):生成 [0, 1, 2, ...., stop-1]

range(start, stop[, step]):生成 [start, start+step, start+2*step, ...... ] ,元素都小于stop

在python2中,range直接返回一个列表,而在python3中,range是一个生成器

使用生成器的原因:为了防止生成的列表会很大,而且可能不会被立即使用

列表推导式

[表达式 for x in xxx]

[表达式 for x in xxx if 条件]

[表达式 for x in xxx for y in yyy]

......

列表常用操作

增加

append

向列表中,追加一个新的元素,在列表的最后

语法:l.append(x)

会直接修改原列表,返回值为None

insert

在列表指定位置追加一个新的元素

在指定索引的前面

语法:l.insert(index, obj)

会直接修改原列表

extend

给列表扩展另外一个可迭代序列

语法:l.extend(iterable)

会直接修改原列表

乘法操作

l * n:列表l,内容重复n次

不修改原列表

加法操作

l1 + l2:组合l1和l2

不修改原列表

删除

del 语句

del 语句可以删除一个指定的元素

(del不止可以用于列表,也可以用于普通变量)

del可以删除整个列表,也可以删除某个元素

pop

移除并返回列表中指定索引对应元素

语法:l.pop(index=-1)

返回被移除的元素

remove

移除列表中的指定元素

语法:l.remove(obj)

参数 obj:需要被移除的元素

注意:

  • 会直接修改原列表
  • 如果元素不存在,会报错
  • 如果存在多个元素,则只会删除最左边的一个
  • 注意,在循环中删除列表元素,有时候会有坑

修改

l[index] = xxx

查找

索引

l[index]

获取元素索引

l.index(obj)

从左到右进行查找

获取指定元素个数

l.count(obj)

获取多个元素,切片

见字符串操作方法,注意列表是可变的

遍历

通过元素进行遍历

for x in l:
......

通过索引进行遍历

for index in range(len(l) + 1):
......

通过枚举进行遍历

枚举对象:通过枚举函数,生成一个新的对象

函数用于将一个可遍历的对象,组合为一个索引序列,同时列出数据下标和数据

语法:enumerate(sequence, [start=0])

  • sequence:一个序列,迭代器,或者其他支持迭代的对象
  • start:起始位置下标

返回的形式:[(0, obj0), (1, obj1), ......]

for t in enumerate(l):
......

也可以使用元组的解包

for idx, obj in enumerate(l):
......

通过迭代器进行遍历

简单了解一下迭代器!

什么是迭代:访问可迭代元素的一种方式,也就是可以按照顺序访问每一项

可迭代对象:能够被迭代的对象称为可迭代对象

判断依据:能作用域for in

判定方法:

import collections
isinstance(obj, collections.Iterable)

迭代器:

  • 是可以记录遍历位置的对象
  • 从第一个元素开始,往后通过next()函数进行遍历
  • 只能往后,不能向前
  • 判定依据:能作用于next函数,next(obj)
  • 判定方法:
    • import collections
    • isinstance(obj, collections.Iterator)
  • 注意:迭代器也是可迭代对象,所以也可以作用于for in

iter:根据一个可迭代对象返回一个迭代器

为什么会产生迭代器

  1. 仅仅在迭代到某个元素时才处理该元素
  • 在此之前,元素可以不存在
  • 在此之后,元素可以被销毁
  • 特别适合用于遍历一些巨大的或者是无限的集合
  1. 提供了一个统一的访问集合的接口
  • 可以把所有的可迭代对象,转换成迭代器进行使用

迭代器的简单使用

  • 使用next()函数,从迭代器中取出下一个对象,从第一个元素开始
  • 因为迭代器比较常用,所以在python中,可以直接作用于 for in
    • 内部会自动调用迭代器对象,next
    • 会自动处理迭代完毕的错误

注意

  • 如果取出完毕,再继续取,则会报错:StopIteration
  • 迭代器一般不能多次迭代

判定

列表也是序列类型

in 和 not in,同样可以用于列表

用来判断元素是否存在于列表之中

比较

内建函数:cmp()

如果比较的是列表,则针对每个元素,从左到右逐一比较

  • 左 > 右 1
  • 左 == 右 0
  • 左 < 右 -1

在python3中不支持这种方式


比较运算符

== < >。。。。。

针对每个元素,从左到右逐一比较

排序

内建函数:sort()

可以对所有可迭代对象进行排序

语法:sorted(iterable, key=None,reverse=False)

参数:

  • iterable:可迭代对象
  • key:排序关键字,值为一个函数,此函数只有一个参数且返回一个值
  • reverse:控制升序降序,默认False,升序

返回值:一个已经排好序的 列表

列表方法 list.sort

语法:list.sort(key=None, reverse=False)

参数:

  • key:排序关键字,值为一个函数,此函数只有一个参数并且返回一个值用来比较
  • reverse:控制升序降序,默认False,升序

乱序

随机打乱一个列表

import random
...
random.shuffle(l)

反转

l.reverse()

l[::-1]

05-28 21:54