ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
## 对list的操作 ### list的长度 还记得str的长度怎么获得吗?其长度是什么含呢?那种方法能不能用在list上面呢?效果如何? 做实验: ~~~ >>> name = 'qiwsir' >>> type(name) <type 'str'> >>> len(name) 6 >>> lname = ['sir','qi'] >>> type(lname) <type 'list'> >>> len(lname) 2 >>> length = len(lname) >>> length 2 >>> type(length) <type 'int'> ~~~ 实验结论: * len(x),对于list一样适用 * 得到的是list中元素个数 * 返回值是int类型 ### 合并list [《有容乃大的list(1)》](_-113)中,对list的操作提到了list.append(x),也就是将某个元素x 追加到已知的一个list后边。 除了将元素追加到list中,还能够将两个list合并,或者说将一个list追加到另外一个list中。按照前文的惯例,还是首先看[官方文档](https://docs.python.org/2/tutorial/datastructures.html)中的描述: > list.extend(L) > > Extend the list by appending all the items in the given list; equivalent to a[len(a):] = L. **向所有正在学习本内容的朋友提供一个成为优秀程序员的必备:看官方文档,是必须的。** 官方文档的这句话翻译过来: > 通过将所有元素追加到已知list来扩充它,相当于a[len(a)]= L 英语太烂,翻译太差。直接看例子,更明白 ~~~ >>> la [1, 2, 3] >>> lb ['qiwsir', 'python'] >>> la.extend(lb) >>> la [1, 2, 3, 'qiwsir', 'python'] >>> lb ['qiwsir', 'python'] ~~~ 上面的例子,显示了如何将两个list,一个是la,另外一个lb,将lb追加到la的后面,也就是把lb中的所有元素加入到la中,即让la扩容。 学程序一定要有好奇心,我在交互环境中,经常实验一下自己的想法,有时候是比较愚蠢的想法。 ~~~ >>> la = [1,2,3] >>> b = "abc" >>> la.extend(b) >>> la [1, 2, 3, 'a', 'b', 'c'] >>> c = 5 >>> la.extend(c) Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: 'int' object is not iterable ~~~ 从上面的实验中,看官能够有什么心得?原来,如果extend(str)的时候,str被以字符为单位拆开,然后追加到la里面。 如果extend的对象是数值型,则报错。 所以,extend的对象是一个list,如果是str,则python会先把它按照字符为单位转化为list再追加到已知list。 不过,别忘记了前面官方文档的后半句话,它的意思是: ~~~ >>> la [1, 2, 3, 'a', 'b', 'c'] >>> lb ['qiwsir', 'python'] >>> la[len(la):]=lb >>> la [1, 2, 3, 'a', 'b', 'c', 'qiwsir', 'python'] ~~~ list.extend(L) 等效于 list[len(list):] = L,L是待并入的list 联想到到[上一讲](_-113)中的一个list函数list.append(),这里的extend函数也是将另外的元素(只不过这个元素是列表)增加到一个已知列表中,那么两者有什么不一样呢?看下面例子: ~~~ >>> lst = [1,2,3] >>> lst.append(["qiwsir","github"]) >>> lst [1, 2, 3, ['qiwsir', 'github']] #append的结果 >>> len(lst) 4 >>> lst2 = [1,2,3] >>> lst2.extend(["qiwsir","github"]) >>> lst2 [1, 2, 3, 'qiwsir', 'github'] #extend的结果 >>> len(lst2) 5 ~~~ append是整建制地追加,extend是个体化扩编。 ### list中某元素的个数 上面的len(L),可得到list的长度,也就是list中有多少个元素。python的list还有一个操作,就是数一数某个元素在该list中出现多少次,也就是某个元素有多少个。官方文档是这么说的: > list.count(x) > > Return the number of times x appears in the list. 一定要不断实验,才能理解文档中精炼的表达。 ~~~ >>> la = [1,2,1,1,3] >>> la.count(1) 3 >>> la.append('a') >>> la.append('a') >>> la [1, 2, 1, 1, 3, 'a', 'a'] >>> la.count('a') 2 >>> la.count(2) 1 >>> la.count(5) #NOTE:la中没有5,但是如果用这种方法找,不报错,返回的是数字0 0 ~~~ ### 元素在list中的位置 [《有容乃大的list(1)》](_-113)中已经提到,可以将list中的元素,从左向右依次从0开始编号,建立索引(如果从右向左,就从-1开始依次编号),通过索引能够提取出某个元素,或者某几个元素。就是如这样做: ~~~ >>> la [1, 2, 3, 'a', 'b', 'c', 'qiwsir', 'python'] >>> la[2] 3 >>> la[2:5] [3, 'a', 'b'] >>> la[:7] [1, 2, 3, 'a', 'b', 'c', 'qiwsir'] ~~~ 如果考虑反过来的情况,能不能通过某个元素,找到它在list中的编号呢? 看官的需要就是python的方向,你想到,python就做到。 ~~~ >>> la [1, 2, 3, 'a', 'b', 'c', 'qiwsir', 'python'] >>> la.index(3) 2 >>> la.index('a') 3 >>> la.index(1) 0 >>> la.index('qi') #如果不存在,就报错 Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError: 'qi' is not in list >>> la.index('qiwsir') 6 ~~~ list.index(x),x是list中的一个元素,这样就能够检索到该元素在list中的位置了。这才是真正的索引,注意那个英文单词index。 依然是上一条官方解释: > list.index(x) > > Return the index in the list of the first item whose value is x. It is an error if there is no such item. 是不是说的非常清楚明白了? 先到这里,下讲还继续有容乃大的list.