列表(可索引的对象,索引是最快的)的操作,最多应用的是append(增,会涉及到开辟空间,可能会有GC的操作)和pop(删,什么都不写,弹出最后一个,或者写索引)
sort是对本身进行修改(就地修改),返回None
list.sort数字和字符串可以混合排序:
类似于:
只要是可迭代对象都可以用sorted(指向修改),内部进行了copy ,操作副本,返回副本(原有list.copy)。
sorted(itrearble, cmp=None, key=None, reverse=False),返回list(新的!)
=号后面是默认值 默认是升序排序的, 如果想让结果降序排列,用reverse=True。最后会将排序的结果放到一个新的列表中, 而不是对iterable本身进行修改。
sorted 和list.sort 都接受key, reverse定制。但是区别是。list.sort()是列表中的方法,只能用于列表。而sorted可以用于任何可迭代的对象。list.sort()是在原序列上进行修改,不会产生新的序列。所以如果你不需要旧的序列,可以选择list.sort()。 sorted() 会返回一个新的序列。旧的对象依然存在。
如果你有一个字典,键是正负都有的只有一个小数点的数字字符串, 你想按数字从小到大排列键,首先把键列表转化为浮点型。对浮点型数据用sorted排序,然后再转化为只有一个小数点的数字字符串:
for i in ['%.1f'%k for k in sorted(float(j) for j in fb_RA_11.keys())]:
对列表序列使用+和*
如果你熟悉字符串拼接的话,*,+一定经常使用,对于列表也是可以使用+和*的,对一个对象复制几份在拼接起来。一次性开辟,采用*乘法扩展list效率更高,append方式一次次加效率比较低。(列表索引操作效率较好)
错误示范:
如果你想使用mylist = [ [] ] * 3 初始化,得到的一个包含三个列表的列表对象,就像这样mylist [[], [], []],中确实包含三个对象,但是其实你的列表中的三个元素都是对同一个列表对象的引用,并且都指向同一个列表。
正解:
切片:
以0为下标开始这样做的好处是:
- 当只有最后一个位置信息时,我们也可以快速看出切片和区间里有几个元素:range(3) 和 my_list[:3] 都返回 3 个元素。
- 当起止位置信息都可见时,我们可以快速计算出切片和区间的长度,用后一个数减去第一个下标(stop - start)即可。
- 这样做也让我们可以利用任意一个下标来把序列分割成不重叠的两部分,只要写成 my_list[:x] 和 my_list[x:] 就可以了
给切片赋值:可迭代对象的重要
enumerate:列表(有序)--> 配对
杨辉三角:
没有说保留数据,只要求打印,所以可以覆盖来节省空间:
转置矩阵: