Python 集合总结

list [value1, value2, …]

获取元素 list[index]
追加 .append(xxx)  .insert(index, xxx) 
删除 .pop()  .pop(index)

特点:有序, 元素值value可修改,元素值value可重复

切片:

>>> L[:] 
['Adam', 'Lisa', 'Bart', 'Paul'] #L[:]实际上复制出了一个新list。
>>> L[1:3]
['Lisa', 'Bart']
>>> L[::2]
['Adam', 'Bart'] #第三个参数表示每N个取一个,上面的 L[::2] 会每两个元素取出一个来,也就是隔一个取一个。

Tips:

range()函数可以创建一个数列:

>>> range(1, 101)
[1, 2, 3, ..., 100]

tuple (value1, value2, …)

获取元素 tuple[index]
获取长度 len(tuple)

特点:有序,元素值value不可修改,追加,删除

Tips: 定义单元素的tuple有歧义,所以 Python 规定,单元素 tuple 要多加一个逗号“,” e.g.

t = (1,)

多元素无所谓

切片: 把list换成tuple,切片操作完全相同,只是切片的结果也变成了tuple

dict { ‘key’: value, …}

获取元素 .get('key') = dict['key']
获取值 	.values() #这个方法把dict转换成一个包含所有value的list
		.itervalues() #效果跟.values()一样
同时获取元素key和值value .items() #items() 方法把dict对象转换成了包含tuple的list,我们对这个list进行迭代,可以同时获得key和value
					  .iteritems() # items() 也有一个对应的 iteritems(),iteritems() 不把dict转换成list,而是在迭代过程中不断给出 tuple,所以, iteritems() 不占用额外的内存。

特点:

  1. 查找速度快;无论dict有10个元素还是10万个元素,查找速度都一样。 而list的查找速度随着元素增加而逐渐下降。
  2. 占用内存大; 不过dict的查找速度快不是没有代价的,dict的缺点是占用内存大,还会浪费很多内容, 而list正好相反,占用内存小,但是查找速度慢。
  3. key不能重复。
  4. 无序
  5. key 的元素必须不可变, 元素值value可修改

Tips:

那.values() 和 .itervalues() 两个方法有何不同之处呢?
1. values() 方法实际上把一个 dict 转换成了包含 value 的list。
2. 但是 itervalues() 方法不会转换,它会在迭代过程中依次从 dict 中取出 value,所以 itervalues() 方法比 values() 方法节省了生成 list 所需的内存。
3. 打印 itervalues() 发现它返回一个 <\dictionary-valueiterator> 对象,这说明在Python中,for 循环可作用的迭代对象远不止 list,tuple,str,unicode,dict等,任何可迭代对象都可以作用于for循环,而内部如何迭代我们通常并不用关心。

set ([value1, value2, …])

添加元素 .add(value)
删除元素 .remove(value)
获取长度 len(tuple)

特点: 无序,元素值value唯一, 无索引;
判断一个元素是否在set中速度很快

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值