转自:http://my.oschina.net/courade/blog/143894
字典(dict)
dict 用 {} 包围
dict.keys(),dict.values(),dict.items()
hash(obj)返回obj的哈希值,如果返回表示可以作为dict的key
del 或 dict.pop可以删除一个item,clear清除所有的内容
sorted(dict)可以吧dict排序
dict.get()可以查找没存在的key,dict.[]不可以
dict.setdefault() 检查字典中是否含有某键。 如果字典中这个键存在,你可以取到它的值。 如果所找的键在字典中不存在,你可以给这个键赋默认值并返回此值。
{}.fromkeys()创建一个dict,例如: {}.fromkeys((‘love‘, ‘honor‘), True) =>{‘love‘: True, ‘honor‘: True}
不允许一个键对应多个值
键值必须是哈希的,用hash()测试
一个对象,如果实现_hash()_方法可以作为键值使用
------------------------------------------------------ 分割线 --------------------------------------------------------------------
以下摘自 http://blog.csdn.net/gemini_dolphin/article/details/7786892
Python中Set和List的性能差距能有数百倍
如果有需要求(集合,列表等)的并集和交集的时候,最好使用Set。
----------------------------------------------------
set转成list方法如下: list转成set方法如下:
s = set(‘12342212‘) l = [‘12342212‘]
print s # set([‘1‘, ‘3‘, ‘2‘, ‘4‘]) s = set(l[0])
l = list(s) print s # set([‘1‘, ‘3‘, ‘2‘, ‘4‘])
l.sort() # 排序 m = [‘11‘,‘22‘,‘33‘,‘44‘,‘11‘,‘22‘]
print l # [‘1‘, ‘2‘, ‘3‘, ‘4‘] print set(m) # set([‘11‘, ‘33‘, ‘44‘, ‘22‘])
可见set和lsit可以自由转换,在删除list中多个/海量重复元素时,可以先转换成set,然后再转回list并排序(set没有排序)。此种方法不仅方便且效率较高。
python的dict,set,list,tuple简单分析
原文:http://www.cnblogs.com/muyouking/p/6413039.html