列表拼接三种方式
列表拼接主要有以下三种方式:
- 最简单的使用“+”;
- 使用切片赋值的方法;
- 使用列表自带的extend方法
方式一:简简单单的“+”
>>> list1 = [1,2,3] >>> list2 = [4,5,6] >>> id(list1) 4408465160 >>> id(list2) 4408325512 >>> list1 = list1 + list2 >&<a>本文来源gao($daima.com搞@代@#码8网^</a>gt;> list1 [1, 2, 3, 4, 5, 6] >>> id(list1) 4408504776
此方法易于理解,但你会发现其实list1已经不是原来那个list1了,list1的id值已经发生改变。
方法二:切片赋值
在这里,我们发现使用切片赋值的拼接就地执行,即它会修改原来的列表,但易读性不高
>>> list1 = [1,2,3] >>> list2 = [4,5,6] >>> id(list1) 4408465160 >>> id(list2) 4408504776 >>> list1[len(list1):len(list1)] = list2 >>> list1 [1, 2, 3, 4, 5, 6] >>> id(list1) 4408465160
方式三:列表自带的extend()
>>> list1 = [1,2,3] >>> list2 = [4,5,6] >>> id(list1) 4408325512 >>> list1.extend(list2) >>> list1 [1, 2, 3, 4, 5, 6] >>> id(list1) 4408325512
这里,你会发现列表自带的extend()也是就地执行,即它会修改原来的列表,直接在原来的列表后面拼接新列表。
综合上面三种方式,第一种的使用“+”拼接需要易于理解,但却不是就地执行,而是新开辟一块空间来存放新列表;第二种比较难于理解;还是Python列表自带的extend()拼接列表函数较为友好。
列表去重的三种方式
例如有以下一个列表:需要你进行去重,你能想到哪些方法呢?
num_list = [1,8,9,1,2,3,4,6,5,7,10,5,6,8,3,4]
利用集合set的特性
第一种方法(大家第一个都会想到的吧):利用集合set的特性
集合set特性:元素不能重复
>>> num_list = [1,8,9,1,2,3,4,6,5,7,10,5,6,8,3,4] >>> new_list = list(set(num_list)) >>> new_list [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
利用字典key的不可重复属性
第二张方法(与集合拥有相同特性的):那么就是字典的键啦
先介绍一下函数dict.fromkeys(序列,设置键对应的值),返回一个由序列的元素作为键,设置的值作为所有键的值的字典,值省略的话所有键的值将默认为None;如果设置了值的话所有的键将会赋予同一个值,看例子:
>>> dict1 = dict.fromkeys([1,2,3,4]) >>> dict1 {1: None, 2: None, 3: None, 4: None} >>> dict1 = dict.fromkeys([1,2,3,4],5) >>> dict1 {1: 5, 2: 5, 3: 5, 4: 5}