一、Python序列
Python中常见的序列结构有列表、元组、字符串、字典、集合以及range等对象,也支持很多类似的操作。
列表、元组、字符串支持双向索引,第一个元素下标为0,第二个元素下标为1,以此类推;最后一个元素下标为-1,倒数第二个元素下标为-2,以此类推。
列表是Python中内置有序可变序列,列表的所有元素放在一对中括号”[]”中,并使用逗号分隔开。
当列表元素增加或删除时,列表对象自动进行扩展或收缩内存,保证元素之间没有缝隙。
在Python中,一个列表中的数据类型可以各不相同,可以同时分别为整数、实数、字符串等基本类型,甚至是列表、元组、字典、集合以及其他自定义类型的对象。
列表常用方法:
1、列表创建与删除
使用“=”直接将一个列表赋值给变量即可创建列表对象。
也可以使用list()函数将元组、range对象、字符串或其他类型的可迭代对象类型的数据转换为列表。
range对象本身不是列表,也不是对象。可用list()函数或其他方法将其转换为列表。
当不再使用时,使用del命令删除整个对象,如果列表对象所指向的值不再有其他对象指向,Python将同时删除该值。
2、列表元素的增加
(1)可以使用“+”运算符将元素添加到列表中。
严格意义上来讲,这并不是真的为列表添加元素,而是创建一个新的列表,并将原列表中的元素和新元素依次复制到新列表的内存空间。由于涉及大量元素的复制,该操作速度较慢,在涉及大量元素添加时不建议使用该方法。
(2)使用列表对象的append()方法,原地修改列表,是真正意义上的在列表尾部添加元素,速度较快。
所谓“原地”,是指不改变列表在内存中的首地址。
列表中包含的是元素值的引用,而不是直接包含元素值。如果是直接修改序列变量的值,则与Python普通变量的情况是一样的,而如果是通过下标来修改序列中的元素的值或通过可变序列对象自身提供的方法来增加和删除元素时,序列对象在内存中的起始地址是不变的,仅仅是被改变值的元素地址发生变化,也就是所谓的“原地操作”。
(3)使用列表对象的extend()方法可以将另一个迭代对象的所有元素添加至该列表对象的尾部。通过extend()方法来增加到表元素也不改变其内存首地址,属于原地操作。
(4)使用列表对象的insert()方法将元素添加至列表的指定位置
尽可能从列表尾部进行元素的增加与删除操作。
列表的insert()可以在列表的任意位置插入元素,但由于列表的自动内存管理功能,insert()方法会涉及到插入位置之后所有元素的移动,这会影响处理速度。
类似的还有后面介绍的remove()方法以及使用pop()函数弹出列表非尾部元素和使用del命令删除列表非尾部元素的情况。
(5)使用乘法来扩展列表对象,将列表与整数相乘,生成一个新列表,新列表是原列表中元素的重复。
(6)当使用*运算符将包含列表的列表重复并创建新列表时,并不创建元素的复制,而是创建已有对象的引用。因此,当修改其中一个值时,相应的引用也会被修改。
3、列表元素的删除
(1)使用del命令删除列表中的指定位置上的元素。
(2)使用列表的pop()方法删除并返回指定(默认为最后一个)位置上的元素,如果给定的索引超出了列表的范围则抛出异常。
(3)使用列表对象的remove()方法删除首次出现的指定元素,如果列表中不存在要删除的元素,则抛出异常。
4、列表元素访问与计数
(1)使用下标直接访问列表元素,如果指定下标不存在,则抛出异常。
(2)使用列表对象的index()方法获取指定元素首次出现的下标,若列表对象中不存在指定元素,则抛出异常。
(3)使用列表对象的count()方法统计指定元素在列表对象中出现的次数。
5、成员资格判断
如果需要判断列表中是否存在指定的值,可以使用count()方法,如果存在则返回大于0的数,如果返回0则表示不存在。或者,使用更加简洁的“in”关键字来判断一个值是否存在于列表中,返回结果为“True”或“False”。
6、切片操作
切片是Python序列的重要操作之一,适用于列表、元组、字符串、range对象等序列。
切片使用2个冒号分割的3个数字来完成。第一个数字表示切片开始位置(默认为0),第二个数字表示切片截止(但不包含)位置(默认为列表长度),第三个数字表示切片的步长(默认为1),当步长省略时可以顺便省略最后一个冒号。可以使用切片来截取列表中的任何部分,得到一个新列表,也可以通过切片来修改和删除列表中部分元素,甚至可以通过切片操作为列表对象增加元素。
切片操作不会因为下标越界而抛出异常,而是简单地在列表尾部截断或者返回一个空列表,代码具有更强的健壮性。
可以使用切片来原地修改列表内容。
使用del与切片结合来删除列表元素
7、列表排序
使用列表对象的reserve方法进行原地排序,支持多种不同的排序方法。
使用内置函数sorted对列表进行排序并返回新列表。
使用列表对象的reserve方法将元素原地逆序。
8、用于序列操作的常用内置函数
len(列表):返回列表中的元素个数,同样适用于元组、字典、集合、字符串等。
max(列表)、min(列表):返回列表中的最大或最小元素,同样适用于元组、字典、集合、range对象等。
9、列表推导式
列表推导式使用非常简洁的方式来快速生成满足特定需求的列表,代码具有非常强的可读性。