流畅的python第二章序列构成的数组学习记录

python内置序列类型概览

列表推导和生成器表达式

列表推导是构建列表的快捷方式,而生成器表达式可以用来创建其他任何类型的序列

列表推导的示例

>>>test = [i*2 for i in range(3)]
>>>test
[0,2,4]

使用列表推导通常的原则是,只能列表推导来创建新的列表,并且尽量保持简短。

python2中列表推导可能有变量泄露问题,而python3解决了变量泄露问题

列表推导和map/filter的对比

生成器表达式

虽然也可以用列表推导来初始化元组,数组或其他序列类型,但是生成器表达式是更好的选择。因为生成器表达式背后遵守了迭代器协议,可以逐个的产出元素,而不是先建立一个完整的列表,然后在吧这个列表传递到某个构造函数里。更节省内存

使用生成器表达式初始化元组和数组

元组的使用

元组除了用作不可变的列表,还可以用于没有字段名的记录

元组和记录

元组其实是对数据的记录,元组的每个元组都存放了记录中的一个字段的数据,外加这个字段的位置。

元组拆包

元组拆包可以使用*开帮助我们把注意力集中在元组的部分元素上

元组拆包还可以应用在嵌套结构中

具名元组

collections.namedtuple是一个工厂函数。可以用来构建一个带字段名的元组和一个有名字的类

除了从普通元组集成来的属性外,具名元组还有一些自己专有的属性。_fields,_make,_asdict()

不可变列表的元组

除了增减元素相关的方法之外,元组支持列表的其他所有方法。

列表或元组的方法和属性

对象切片

s[a:b:c]对s在a和b之间以c为间隔取值,c可以为负,反向取值

多维切片和省略

切片赋值

 

 对序列使用+和*

拼接的过程中,两个被操作的序列都不会被修改,python会新建一个包含同样类型数据的序列作为拼接的结果。

+和*都遵循这个规律,不修改原有的操作对象,而是构建一个全新的序列

序列的增量赋值

+=背后的特殊方法是__iadd__但是如果一个类没有实现该方法,python会调用__add__

*=背后的特殊方法是__imul__类似于+=

得到的教训

不要把可变对象放在元组里面

增量赋值不是一个原子操作

查看python字节码并不难,他对了解代码背后的运行机制很有帮助

list.sort方法和内置函数sorted

list.sort就地排序,对原列表进行排序并返回None。对原列表直接操作

sorted则不是,会创建新的列表,该列表是原列表进过排序的。

reverse参数,True降序排列,默认False

key参数用于对比的关键字

bisect管理已排序的序列

bisect模块包含两个主要函数,bisect,insort,两个函数都利用二分查找算法来在有序序列中查找或插入元素

bisect.insort(seq,item)将item插入seq中,并保持seq升序排序

数组

如果我们需要一个只包含数字的列表,那么array.array比list更高效,数组支持所有跟可变序列有关的操作。包括pop,insert和extend。另外,数组还提供从文件读取和存入文件的更快的方法frombytes和tofile

列表和数组的属性和方法

 

 

内存视图memoryview

scipy和numpy

双向队列和其他形式的队列

collections.deque类是一个线程安全可以快速从两端添加或者删除元素的数据类型。

列表和双向队列的方法

 

posted @ 2018-01-24 11:27  菲菲菲菲菲常新的新手  阅读(227)  评论(0编辑  收藏  举报