python的6个序列的内置类型
序列是python的最基本数据结构,序列的每个元素都分配一个数字,它的索引,第一个是0,第二个是1,依次类推;
python的6个内建的序列分别是列表,元祖,字符串,unicode字符串,buffer对象和xrange对象;
序列通用操作包含:索引,长度,组合(序列相加),重复(乘法),分片,检查成员,遍历,最大值和最小值;
列表
列表是python最常用的数据类型,使用方括号定义,元素之间使用逗号隔开;
列表的常用方法
1.定义一个列表
#定义一个空的列表
list1 = []
print(list1,type(list1))
#定义一个单值列表
list2 = ['hello']
print(list2,type(list2))
#定义一个普通列表
list3 = [1,'hello',[2,'world']]
print(list3,type(list3))
输出结果:
[]
['hello']
[1, 'hello', [2, 'world']]
2.列表的索引
list4 = [1,2,3,4,5,6]
print(list4[:]) #索引从0开始到索引值为列表长度结束
print(list4[:4]) #索引从0开始到4结束
print(list4[2:]) #索引从0开始到列表长度结束
print(list4[1:6:2]) #索引从1开始到6结束,步长为2
print(list4[::-1]) #将列表元素进行反转显示
输出结果:
[1, 2, 3, 4, 5, 6]
[1, 2, 3, 4]
[3, 4, 5, 6]
[2, 4, 6]
[6, 5, 4, 3, 2, 1]
3.列表的增加
1.使用append()函数追加其他元素到列表里
list4.append(7)
print(list4)
list4.append('abc')
print(list4)
输出结果:
[1, 2, 3, 4, 5, 6, 7]
[1, 2, 3, 4, 5, 6, 7, 'abc']
3.2.extend()函数追加其他列表的元素到指定的列表;
list4.extend(list3)
print(list4)
输出结果:
[1, 2, 3, 4, 5, 6, 7, 'abc', 1, 'hello', [2, 'world']]
3.使用insert()函数为列表指定位置添加元素
list4.insert(2,'100')
print(list4)
输出结果:
[1, 2, '100', 3, 4, 5, 6]
4.列表的删除
1.remove()函数删除后列表的值进行改变
list4.remove('100')
print(list4)
list4.remove(5)
print(list4)
输出结果:
[1, 2, 3, 4, 5, 6]
[1, 2, 3, 4, 6]
2.pop()函数删除指定索引值
list4.pop() #默认情况下删除最后一个元素
print(list4)
list4.pop(-1) #删除列表最后一个元素
print(list4)
list4.pop(1) #删除列表索引值为2的元素
print(list4)
输出结果:
[1, 2, 3, 4]
[1, 2, 3]
[1, 3]
3.del()删除列表元素,也可以通过索引以及切片删除指定位置的元素
del(list4[0])
print(list4)
del(list4) #将整个列表删除,输出值没有
print(list4)
输出结果:
[3]
4.clear()函数清空列表的元素,使之成为空元素
list5 = [9,8,7,6,5]
list5.clear()
print(list5)
输出结果:
[]
5.列表的修改
l1 = [0,1,2,3,4,5]
l1[3] = 'abc'
print(l1)
输出结果:
[0, 1, 2, 'abc', 4, 5]
l1 = [0,1,2,3,4,5]
l1[:3]='abcdef'
print(l1)
输出结果:
['a', 'b', 'c', 'd', 'e', 'f', 3, 4, 5]
6.列表的复制
在python中,对于复制问题,存在深拷贝和浅拷贝问题;两者的区别在于,从原来的列表里面复制出新的列表,修改其中的任意一个是否会对另外一个造成影响,即这两个列表在内存中是否存储在同一区域,这是区分深拷贝和浅拷贝的重要依据;
复制的愿望是复制的列表之间不会相互影响;
1.直接赋值方法,是一种非拷贝方法;
l1 = [1,2,3,4,5]
l2 = l1 #将l1的值赋值给l2
print(l1,id(l1))
print(l2,id(l2))
#修改l1查看是否会影响到l2
l1.append(6)
print(l1,id(l1))
print(l2,id(l2))
输出结果:
[1, 2, 3, 4, 5] 7758408
[1, 2, 3, 4, 5] 7758408
[1, 2, 3, 4, 5, 6] 7758408
[1, 2, 3, 4, 5, 6] 7758408
修改l1导致l2也随之变化;
2.浅拷贝的方式
l2 = [1,2,3,'abc','efg']
l3 = l2.copy()
print(l2,id(l2))
print(l3,id(l3))
l2.append('hij')
print(l2,id(l2))
print(l3,id(l3))
输出结果:
[1, 2, 3, 'abc', 'efg'] 5136968
[1, 2, 3, 'abc', 'efg'] 5137032
[1, 2, 3, 'abc', 'efg', 'hij'] 5136968
[1, 2, 3, 'abc', 'efg'] 5137032
l2 = [1,2,3,'abc','efg']
l4 = l2[:]
print(l2,id(l2))
print(l4,id(l4))
输出结果:
[1, 2, 3, 'abc', 'efg'] 34807752
[1, 2, 3, 'abc', 'efg'] 33972808
3.深拷贝的方式
deepcopy()方法,无论多少层,无论怎样的形式,得到新的列表和原来无关;
使用该函数时需要导入copy模块;
import copy
l2 = [1,2,3,'abc','efg']
l3 = copy.deepcopy(l2)
print(l2,id(l2))
print(l3,id(l3))
l3.append('hij')
print(l2,id(l2))
print(l3,id(l3))
输出结果:
[1, 2, 3, 'abc', 'efg'] 31946504
[1, 2, 3, 'abc', 'efg'] 31945288
[1, 2, 3, 'abc', 'efg'] 31946504
[1, 2, 3, 'abc', 'efg', 'hij'] 31945288
7.列表的长度,重复,组合,成员操作以及遍历
l1 = [0,1,2,3,4,5]
l2 = [1,2,3,'abc','efg']
print(len(l2))
print(l1+l2)
print(l1*3)
print(5 in l1)
for i in l1:
print(i)
输出结果:
5
[0, 1, 2, 3, 4, 5, 1, 2, 3, 'abc', 'efg']
[0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5]
True
0
1
2
3
4
5
8.反向列表中的元素
l1 = [0,1,2,3,4,5]
l1.reverse()
print(l1)
输出结果:
[5, 4, 3, 2, 1, 0]
9.列表的排序
列表的sort函数是按照ASSIC码进行排序
l2 = [1,7,3,9,8,5]
l2.sort()
print(l2)
l3 = ['a','f','r','d']
l3.sort()
print(l3)
l4 = [5,8,1,4,'c','f'] #列表的sort函数不支持整型和字符串的排序,不然执行会报错
l4.sort()
print(l4)
输出结果:
[1, 3, 5, 7, 8, 9]
['a', 'd', 'f', 'r']
报错:
TypeError: '<' not supported between instances of 'str' and 'int'
10.列表的zip()函数
zip()将多个序列中的元素配对,从而产生新的元组列表;zip可以接受任意数量的序列,最终得到的元组数量由最短的序列决定;
l1 = [1,2,3,4,5]
l2 = ['a','b','c','d','e']
l3 = [6,7,8,9,10]
l4 = zip(l1,l2,l3)
print(l4,type(l4))
for i in l4:
print(i)
输出结果:
(1, 'a', 6)
(2, 'b', 7)
(3, 'c', 8)
(4, 'd', 9)
(5, 'e', 10)
对于“已压缩的”(zipped)序列,对该序列进行解压(unzip,用*表示);就是将一组行转换为一组列
l4 = [(1, 'a', 6),(2, 'b', 7),(3, 'c', 8),(4, 'd', 9),(5, 'e', 10)]
n1,n2,n3 = zip(*l4)
print(n1)
print(n2)
print(n3)
输出结果:
(1, 2, 3, 4, 5)
('a', 'b', 'c', 'd', 'e')
(6, 7, 8, 9, 10)
列表作为栈使用
使用列表作为堆栈使用,最后一个插入,第一个先出,(后近先出)。要添加到堆栈的顶端使用append()函数,取出堆栈的第一个元素使用pop()函数;
l2 = ['abc',5,8,'efc']
l2.append(1000)
print(l2)
l2.pop()
print(l2)
输出结果:
['abc', 5, 8, 'efc', 1000]
['abc', 5, 8, 'efc']
列表作为队列使用
列表也可以用作队列,其中先添加的元素被最先取出 (“先进先出”);然而列表用作这个目的相当低效。因为在列表的末尾添加和弹出元素非常快,但是在列表的开头插入或弹出元素却很慢 ;
若要实现一个队列, collections.deque 被设计用于快速地从两端操作;