Python中常见的序列结构有列表、元组、字符串、字典、集合以及range等对象,也支持很多类似的操作。
列表、元组、字符串支持双向索引,第一个元素下标为0,第二个元素下标为1,以此类推;最后一个元素下标为-1,倒数第二个元素下标为-2,以此类推。
列表是Python中内置有序可变序列,列表的所有元素放在一对中括号”[]”中,并使用逗号分隔开。
当列表元素增加或删除时,列表对象自动进行扩展或收缩内存,保证元素之间没有缝隙。
在Python中,一个列表中的数据类型可以各不相同,可以同时分别为整数、实数、字符串等基本类型,甚至是列表、元组、字典、集合以及其他自定义类型的对象。
列表常用方法:
使用“=”直接将一个列表赋值给变量即可创建列表对象。
也可以使用list()函数将元组、range对象、字符串或其他类型的可迭代对象类型的数据转换为列表。
range对象本身不是列表,也不是对象。可用list()函数或其他方法将其转换为列表。
当不再使用时,使用del命令删除整个对象,如果列表对象所指向的值不再有其他对象指向,Python将同时删除该值。
严格意义上来讲,这并不是真的为列表添加元素,而是创建一个新的列表,并将原列表中的元素和新元素依次复制到新列表的内存空间。由于涉及大量元素的复制,该操作速度较慢,在涉及大量元素添加时不建议使用该方法。
所谓“原地”,是指不改变列表在内存中的首地址。
列表中包含的是元素值的引用,而不是直接包含元素值。如果是直接修改序列变量的值,则与Python普通变量的情况是一样的,而如果是通过下标来修改序列中的元素的值或通过可变序列对象自身提供的方法来增加和删除元素时,序列对象在内存中的起始地址是不变的,仅仅是被改变值的元素地址发生变化,也就是所谓的“原地操作”。
尽可能从列表尾部进行元素的增加与删除操作。
列表的insert()可以在列表的任意位置插入元素,但由于列表的自动内存管理功能,insert()方法会涉及到插入位置之后所有元素的移动,这会影响处理速度。
类似的还有后面介绍的remove()方法以及使用pop()函数弹出列表非尾部元素和使用del命令删除列表非尾部元素的情况。
如果需要判断列表中是否存在指定的值,可以使用count()方法,如果存在则返回大于0的数,如果返回0则表示不存在。或者,使用更加简洁的“in”关键字来判断一个值是否存在于列表中,返回结果为“True”或“False”。
切片是Python序列的重要操作之一,适用于列表、元组、字符串、range对象等序列。
切片使用2个冒号分割的3个数字来完成。第一个数字表示切片开始位置(默认为0),第二个数字表示切片截止(但不包含)位置(默认为列表长度),第三个数字表示切片的步长(默认为1),当步长省略时可以顺便省略最后一个冒号。可以使用切片来截取列表中的任何部分,得到一个新列表,也可以通过切片来修改和删除列表中部分元素,甚至可以通过切片操作为列表对象增加元素。
切片操作不会因为下标越界而抛出异常,而是简单地在列表尾部截断或者返回一个空列表,代码具有更强的健壮性。
可以使用切片来原地修改列表内容。
使用del与切片结合来删除列表元素。
使用列表对象的reserve方法进行原地排序,支持多种不同的排序方法。
使用内置函数sorted对列表进行排序并返回新列表。
使用列表对象的reserve方法将元素原地逆序。
len(列表):返回列表中的元素个数,同样适用于元组、字典、集合、字符串等。
max(列表)、min(列表):返回列表中的最大或最小元素,同样适用于元组、字典、集合、range对象等。
列表推导式使用非常简洁的方式来快速生成满足特定需求的列表,代码具有非常强的可读性。
元组和列表类型,但属于不可变序列,元组一旦创建,用任何方法都不可以修改其元素。
元组的定义方式和列表相同,但定义时所有元素是放在一对圆括号“()”中,而不是方括号中。
使用“=”将一个元组赋值给变量
使用tuple函数将其他序列转换为元组。
使用del可以删除元组对象,不能删除元组中的元素。
元组中的数据一旦定义就不允许更改。
元组没有append()、extend()和insert()等方法,无法向元组中添加元素。
元组没有remove()或pop()方法,也无法对元组元素进行del操作,不能从元组中删除元素。
从效果上看,tuple()冻结列表,而list()融化元组。
元组的速度比列表更快。如果定义了一些列常量值,而所需做的仅是对它进行遍历,那么一般使用元组而不用列表。
元组对不需要改变的数据进行“写保护”将使得代码更加安全。
元组可用作字典键(特别是包含字符串、数值和其他元组这样的不可变数据的元组)。列表永远不能当作字典键使用,因为列表不是不可变的。
字典是无序可变序列。
定义字典时,每个元素的键和值用冒号分隔,元素之间用逗号分隔,所有的元素放在一对大括号”[]”中。
字典中的键可以为任意不可变数据,比如整数、实数、复数、字符串、元组等等。
globals()返回包含当前作用域内所有全局变量和值的字典。
locals()返回包含当前作用域内所有局部变量和值的字典。
使用=将一个字典赋值给一个变量:
使用dict利用已有数据创建字典
使用dict根据给定的键、值创建字典
以给定内容为键,创建值为空的字典
None无引号,不是字符串,表示未对字典赋值
可以使用del删除整个字典
以键作为下标可以读取字典元素,若键不存在则抛出异常。
使用字典对象的get方法获取指定键对应的值,并且可以在键不存在的时候返回指定值。
使用字典对象的items()方法可以返回字典的键、值对列表。
使用字典对象的keys()方法可以返回字典的键列表。
使用字典对象的values()方法可以返回字典的值列表。
上面的key不表示输出键,而相当于局部循环变量。要单独输出键/值,应在aDict中进行限定。未加特殊说明,默认为键。
当以指定键为下表为字典赋值时,若键存在,则可以修改该键的值;若不存在,则表示添加一个键、值对。
使用字典对象的update方法将另一个字典的键、值对添加到当前字典对象。
使用del删除字典中指定键的元素。
使用字典对象的clear()方法来删除字典中所有元素。
使用字典对象的pop()方法删除并返回指定键的元素。
使用字典对象的popitem()方法删除并返回字典中的一个元素。
首先生成包含1000个随机字符的字符串,然后统计每个字符的出现次数
集合是无序可变序列,使用一对大括号界定。元素不可重复,同一个集合中每个元素都是唯一的。
集合中只能包含数字、字符串、元组等不可变类型(或者是可哈希)的数据,而不能包含列表、字典、集合等可变类型的数据。
直接将集合赋值给变量。
使用set将其他类型数据转换为集合。
使用del删除整个集合。
当不在使用某个集合时,可以使用del命令删除整个集合。集合对象的pop()方法弹出并删除其中一个元素,remove()方法直接删除指定元素,clear()方法清空集合等运算。
Python集合支持交集、并集、差集等运算。