一、python数据结构:
1)List:可更改的类型,下面是List的一些方法:
1、list.append(x):把一个元素添加到列表的结尾,a[len(a):] = [x]。
2、list.extend(L):通过添加指定列表的所有元素来扩充列表,相当于 a[len(a):] = L。
3、list.insert(i,x):在指定位置插入一个元素。第一个参数是准备插入到其前面的那个元素的索引,例如a.insert(0,x)会插入到整个列表之前,而a.insert(len(a), x)相当于a.append(x)。
4、list.remove(x):删除列表中值为 x 的第一个匹配元素。如果没有这样的元素,就会返回一个错误。
5、list.pop([i]):从列表的指定位置移除元素,并将其返回。如果没有指定索引,a.pop()返回最后一个元素。元素随即从列表中被移除。(方法中i两边的方括号表示这个参数是可选的,而不是要求你输入一对方括号,你会经常在 Python 库参考手册中遇到这样的标记。)
6、list.clear():移除列表中的所有项,等于del a[:]。
7、list.index(x):返回列表中第一个值为 x 的元素的索引。如果没有匹配的元素就会返回一个错误。
8、list.count(x):返回x在列表中出现的次数。
9、list.sort():对列表中的元素进行排序(默认从小到大排序)。
10、list.reverse():倒排列表中的元素。
11、list.copy():返回列表的浅复制,等于a[:]。
备注:
1、python浅复制和深复制的区别:对于可更改类型(复合型对象),复制有分浅复制和深复制两种类型。
①浅复制(list.copy()):意味着新建一个对象B,但是其子元素仍然指向对应原对象A的子对象(也就是说,A中原有的数据改变,B也会跟着改变)。同时,只会对原对象A这一层进行拷贝,而不会递归的对子对象也进行拷贝(类似A新增操作就不会对B起作用)。
举个例子: A = [[1,2],[2,3,4]]
B = A.copy()
print(B) #输出:[[1,2],[2,3,4]]
C = [1,3,4]
A.append(C)
print(A) #输出:[[1,2],[2,3,4],[1,3,4]]
print(B) #输出:[[1,2],[2,3,4]]
A[0][0] = 'a'
print(A) #输出:[['a',2],[2,3,4],[1,3,4]]
print(B) #输出:[['a',2],[2,3,4],[1,3,4]]
总结:也就是说,对对象A进行浅复制之后得到的B对象,对原本复制的内容,A更改则B跟着改,但是自浅复制完后,A对除原有数据外进行操作,例如增加列表元素,都不会对B造成影响。
②深复制:意味着新建一个对象B,但是其子元素不再指向对应原对象A的子对象,类似于克隆出来的完全独立体。(也就是说,A中原有的数据 改变,B不会跟着改变)。自然往A中的其他任何操作,都应该不会对B有任何影响的了。
重用上面例子的数据举例:
D = copy.deepcopy(A)
print(D) #[[1,2],[2,3,4]]
A[0][0] = 'a'
print(A) #输出:[['a',2],[2,3,4],[1,3,4]]
print(B) #输出:[['1',2],[2,3,4],[1,3,4]]数据不会跟着改变
2、用append()和不指定索引的pop()方法可以实现列表充当堆栈的进出操作。
3、列表推导式:每个列表推导式都在for之后跟一个表达式,然后又零到多个for/if语句,返回结果是一个根据表达从其后的for和if 上下文环境中生成出来的列表。如果希望表达式推导出一个元组,就必须使用括号。举个例子说明一下怎么用即可:
>>> A = [1,2,3]
>>> [10*i for i in A] #输出:[10,20,30]
>>> [[i, i**2] for i in A] #输出:[[1, 1],[2, 4],[3,9]]
2)嵌套列表解析
这部分就讲一个矩阵行列倒置:
eg:
>>> A = [
[1, 2, 3, 4],
[5, 6, 7, 8],
[9, 10, 11, 12],
]
>>> [[row[i] for row in A] for i in range(4)] #进行行列倒置
>>> print(A)#输出:[[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
3)遍历技巧
1、字典遍历时,关键字和对应的值可以使用items()方法同时解读出来:
eg:>>> A = {'a': 'b', 'c': 'd'}
>>> for i, j in A.items():
>>> print(k, v)
2、序列遍历时,索引位置和对应值可以使用enumerate()函数同时得到:
eg:>>> for i, j in enumerate(['a', 'b', 'c']):
>>> print(i, v)
3、同时遍历两个或者更多的序列时,可以使用zip()组合:
eg:>>> A = ['name', 'phone', 'school']
>>> B = ['yangrongkuan','18813299877','scnu']
>>> for i,j in zip(A, B):
>>> print('What is your {0}? It is {1}.'.format(i, j))
4、反向遍历一个序列:
eg:>>> for i in reverse(range(1,10,2)):
>>> print(i)
5、要按顺序遍历一个序列,可以使用sorted()函数返回一个已排序的序列,并不修改原值:
eg:>>> basket = ['apple', 'orange', 'apple', 'pear', 'orange', 'banana']
>>> for i in sorted(set(basket)):#不用指定按照什么顺序进行排序的
>>> print(i)