例子:、a = [1,2,3] b=[1,2,3] 判断 a is b 得到false is 方法是比较两个对象的内存地址,可用于比较是否是同一个对象。
例子: a = (1, 2, 3, [1, 2, 3]) 执行a[2].append(4)会发生什么?
结果会添加进去,而且我认为不冲突,在元组内存储的是引用列表的对象,不是真正的列表,如下图
keyi可以看出这样操作并不冲突
例子
>>>a = [1,2,3] >>>a = (1, 2, 3)
>>>id(a) >>>id(a)
4000000 10000000
>>>a*=2 >>>a*=2
[1,2,3,1,2,3] (1,2,3,1,2,3)
>>>id(a) >>>id(a)
4000000 2000000
可以看出对于列表,进行自乘操作,将会修改到本身,并且不改变内存地址,对于元祖来说,进行自乘将会在新的内存内重新生成一个元祖
列表与元祖都是常用的数据结构,主要区别就是可变与不可变的区别
list : 可以迭代,拼接,切片,排序
常用方法 append(数据) remove(数据) extend(列表)pop() clear() count() reverse()
列表生成式,可以快速生成列表
[ x for x in range(100)] 生成0~99的列表
[func(x) for x in range(100) if x>70] 根据字面意思可以理解
使用列表推导可以替代map
list(map(函数名, 可迭代的)) 生成一个列表 列表里面的值是可迭代数据结构中的数据经过函数处理的值
排序函数的使用
list.sort()和sorted(list)前者是直接对列表进行排序,后者是对列表排序并生成一个新的对象
>>>a = [1,3,2] >>>a = [1, 3, 2]
>>>a.sort() >>>id(a)
>>>a 10000000
[1,2,3] >>>id(sorted(a))
20000000
元祖
元祖通常被看成不可变的列表,但是元祖因为他的不可变性质,可以被当做记录来使用。
元祖拆包
a, b, c = (1, 2, 3) 输出 (1, 2, 3)
a, *b, c = (1, 2, 3, 4) 输出(1, [2, 3], 4)
具名元祖:特别像结构体
from collection import namedtuple
Person = namedtupln(‘Person’, ‘name age sex country’) 创建一个具名元祖 ,前面是类名,后面存放字段名(空格隔开的字段 或者可以迭代的字符串)
xiaoming = Person(‘小明’, ‘男’, ‘17’, ‘中国’)
xiaoming.name 可以调用