python(set、dict)

时间:2023-03-10 02:16:51
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}