python(set、dict)
一、集合
它的元素是唯一的,并无序的。
1、集合定义
s = set()
s = {1, 2, 3}
2、集合的方法
update版本的集合运算是在原集合上进行修改,返回值为None。
- add()表示增加一个元素到集合。当添加一个已经存在的元素时,不会抛出异常。可hash的可以作为集合的元素,不可hash(list,set,bytearray dict)的不可以作为集合的元素。
- update()表示增加一个可迭代对象。
- remove()表示从集合中删除一个存在的元素,否则抛出一个KeyError异常。
- discard()表示从集合中删除一个元素,当元素不存在时不抛出异常。
- pop()表示从集合中随机返回一个元素,并从集合中删除此元素。当删除一个空集合时,抛出一个KeyError异常。
- clear()表示清空所有元素。
- difference()表示不在另一个集合的所有元素,返回一个新集合。
- intersection()表示两个集合的交集,返回一个新集合。
- union()表示两个集合的并集,返回一个新集合。
- symmetric_difference()表示返回两个集合不相交的元素,返回一个新集合。
- difference_update()表示在原集合修改,只保留第一个集合不相交的元素。
- intersection_update()表示在原集合修改,保留两个集合的相同元素。
- issuperset()表示是否为超集。
- issubset()表示是否为子集。
- isdisjoint()表示两个集体不相交。
二、字典
字典是一个键值对结构。它的Key必须是可hash的值并且是唯一的,value可以是任意的值。
1.字典定义
dt = dict()
dt = {}
2.下标操作
dt = {'a':2,'b':3}
dt['c']=4
3.字典的方法
- update()表示增加元素,如果增加的key相同是就修改原来key的值。它的参数可以是以下几种情况:字典、由二元组构成的可迭代对象、关键字参数。
dt = {'a':2,'b':3} dt['c'] = 4 dt.update([('g',3),('h',2)]) dt.update({'f':3,'e':2}) dt.update(u=22) print(dt) #结果:{'a': 2, 'b': 3, 'c': 4, 'g': 3, 'h': 2, 'f': 3, 'e': 2, 'u': 22}
- pop()表示从字典中删除指定的key,如果key不存在就抛出keyError异常,但可以指定默认值时则不抛出异常。
dt = {'a': 2, 'b': 3, 'c': 4, 'g': 3, 'h': 2, 'f': 3, 'e': 2, 'u': 22} d = dt.pop('gg',-2) print(d) print(dt) #d结果:-2 #dt结果:{'a': 2, 'b': 3, 'c': 4, 'g': 3, 'h': 2, 'f': 3, 'e': 2, 'u': 22}
- popitem()表示从字典中随机删除一个key,并返回一个键值对的元组。如果删除一个空字典时抛出一个KeyError异常。
dt = {'a': 2, 'b': 3, 'c': 4, 'g': 3, 'h': 2, 'f': 3, 'e': 2, 'u': 22} d = dt.popitem() print(d) print(dt) #d结果:('u', 22) #dt结果:{'a': 2, 'b': 3, 'c': 4, 'g': 3, 'h': 2, 'f': 3, 'e': 2}
- clear()表示清空字典所有键值对。
- get()表示访问指定键的值,并可以给默认值。
- setdefault()表示可以为某个key指定默认值。
三、字典的应用
- 字典可能通过keys()方法返回所有keys,也可以通过values()方法返回所有的值。
- 用len()方法统计字典的长度。
1、如何遍历一个字典?
dt = {'a':1,'b':2,'c':3} for k in dt.keys(): print('{}=>{}'.format(k,dt[k]),end=' ') #结果:a=>1 b=>2 c=>3
dt = {'a':1,'b':2,'c':3} for k,v in dt.items(): print('{}=>{}'.format(k,v),end=' ')
#结果:a=>1 b=>2 c=>3
2、enumerate用法
enumerate()是python的内置函数,并返回的是一个enumerate对象。对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串),enumerate将其组成一个索引序列,利用它可以同时获得索引和值。
lt = [1, 2, 3, 4, 5, 6] for k,v in enumerate(lt): print('{}=>{}'.format(k,v),end=' ') #结果:0=>1 1=>2 2=>3 3=>4 4=>5 5=>6
enumerate还可以接收第二个参数,用于指定索引起始值。
lt = [1, 2, 3, 4, 5, 6] for k,v in enumerate(lt,1): print('{}=>{}'.format(k,v),end=' ') #结果:1=>1 2=>2 3=>3 4=>4 5=>5 6=>6
3、OrderedDict的用法
collections模块里有一个OrderedDict,它可以记住字典中插入元素的先后顺序。
from collections import OrderedDict ot = OrderedDict() ot['b']=2 ot['a']=1 ot['e']=4 ot['1']=1 ot['c']=3 ot['2']=2 for k,v in ot.items(): print('{}=>{}'.format(k,v),end=' ')
lt = {'a', 'b', 'c', 'd'} print(dict.fromkeys(lt,True)) #结果:{'a': True, 'b': True, 'd': True, 'c': True}