(1) fromkeys( )
描述
fromkeys()通过给定keys和values来创建一个新的字典,其中包括两个参数,第一个参数表示字典的健,第二个参数表示字典所有键对应的初始值。
语法
dict.fromkeys(keys, value)
keys: 新的字典的键的可迭代对象(字符串、列表、元祖、字典)
value: 字典所有键对应的初始值
k = [1,2,3]
v = 'a'
x = dict.fromkeys(k, v)
print(x)
结果:
{1: 'a', 2: 'a', 3: 'a'}
(2) deepcopy( )和copy( )
在介绍之前,先说明一下什么是父对象,什么是子对象。
以为例:a = [1, 2, 3, [4, 5]]
父对象:最外围的对象本身,即一级对象,1, 2, 3, [ ]
子对象:内部元素,即二级对象,4, 5
copy( ): 只拷贝父对象,不会拷贝子对象
deepcopy( ): 父对象和子对象都会拷贝
import copy
a = [1, 2, 3, [4, 5]]
b = copy.copy(a)
c = copy.deepcopy(a)
print('原始复制')
print(b)
print(c)
"""修改父对象"""
a.append(6)
print('修改父对象')
print(b)
print(c)
"""修改子对象"""
a[3].append(7)
print('修改子对象')
print(b)
print(c)
结果:
[1, 2, 3, [4, 5]]
[1, 2, 3, [4, 5]]
修改父对象
[1, 2, 3, [4, 5]]
[1, 2, 3, [4, 5]]
修改子对象
[1, 2, 3, [4, 5, 7]]
[1, 2, 3, [4, 5]]
从上面的代码结果,我们可以发现,因为deepcopy( )和copy( )均拷贝父对象,所以在修改父对象的时候,b和c均不改变。但是,copy( )不拷贝子对象,所以当子对象修改的时候,b也跟着修改了。
(3) sort( )和sorted( )
sort( ): 使用sort()方法对list排序会修改list本身,无法保留原来的list,不会返回新list。
sorted( ): 可以保留原来的list,并且可以返回新的list,因此感觉这种方法会比较好点。
a = [1, 3, 6 ,1, 55, 4]
b = sorted(a)
print('a:', a)
a.sort()
print('a:', a)
print('b:', b)
结果:
a: [1, 3, 6, 1, 55, 4]
a: [1, 1, 3, 4, 6, 55]
b: [1, 1, 3, 4, 6, 55]