文章目录
- 字典
- 1、介绍
- 2、创建字典
- 3、字典内元素的访问
- 4、字典元素的添加、修改、删除
- 5、关于字典的其它操作
- 6、字典存储底层原理
- 集合
- 1、介绍
- 2、相关操作
- 3、集合元素的添加
- 4、移除元素
字典
1、介绍
字典可以当做c++STL中的map容器(配图看着很像容器)来进行理解。字典类型的数据有两部分组成:键和值,也称为键值对。Python中关于键值对的语法是这样规定的:{key1:value1,key2:value2},例如:
d = {key1 : value1, key2 : value2
下图是对键值对关联的关系说明
字典中的键(key)是不可以重复的,而且必须是不可更改的数据类型,比如:字符串、整数、元组、浮点数,例如列表、字典、集合这些可变对象是不能作为键,并且键不能重复。
字典中的值(value)可以为任意数据,并且可以重复。
2、创建字典
创建字典有四种方法
(1)使用大括号进行创建:
a = {1:9,7:0}
print(a) #{1: 9, 7: 0}
dirr = {'Alice': '2341', 'Beth': '9102', 'Cecil': '3258'}
dir1 = { 'abc': 456 }
dir2 = { 'abc': 123, 98.6: 37 }
(2)使用dict关键字进行创建
a = dict(name='123',age=16)
b = dice([('name','xioaming'),('age',18)])
c = {} #空的字典对象
d = dict() #空的字典对象
(3)使用zip进行创建
k = ['name',age,'job']
v = ['XiaoHong','17','student']
d = dict(zip(k,v)) # 此时k里面的内容为键,v里面的内容为值
b = dict(zip(v,k)) # 此时v里面的内容为键,k里面的内容为值
4、通过fromkays创建键为空的字典
a = dict.fromkeys(['name','age','job'])
''' a的内容为 {'name':None,'age':None,'job':None} '''
3、字典内元素的访问
1、通过 [键] 获得“值”,如果键不存在则抛出异常。
d = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
print ("d['Name']: ", d['Name']) #dict['Name']: Runoob
print ("d['Age']: ", d['Age']) #dict['Age']: 7
print ("d['job']: ", d['job']) #抛出异常
2、通过 get( “键” ) 方法获得 “值” 。如果 “键” 不存在,则返回None,也可以设定当 “键” 不存在时的默认返回对象。
a = {1:9,7:0}
print(a) # {1:9, 7:0}
print(a.get(1,6)) #9
print(a.get(9,8)) #8
print(a.get(9)) #None
3、列出所有的键值对
a.items() # dict_items([(1, 9), (7, 0)])
4、列出所有的键,列出所有的值
a.keys() # dict_keys([1, 7])
a.values() # dict_values([9, 0])
5、len()返回键值对的个数
len(a) # 2
6、检测一个 “键” 是否在字典中,返回值为True或者False
1 in a # True
6 in a # False
4、字典元素的添加、修改、删除
1、添加
b = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
b['Job'] = "Student" # 添加信息
2、修改
b['Age'] = 8 # 修改 Age
3、删除
能删单一的元素也能清空字典。清空只需一项操作,但是删除操作既可以删除一个键值对也可以删除一个字典 ,如下实例:
dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
del dict['Name'] # 删除键 'Name'
dict.clear() # 清空字典
del dict # 删除字典
5、关于字典的其它操作
1、序列解包操作
序列解包可以用于元组、列表、字典,使用序列解包会很方便的对多个变量赋值。
序列解包用于字典时,默认是对 “键” 进行操作;如果要对键值对进行操作,则需要使用items();如果需要对 “值” 进行操作,则需要用values()。
s = {'name':'Gao','age':18}
name,age=s
print(name) # name
name,age = s.items()
print(name) # ('name','Gao')
name,age = s.values()
print(name) # Gao
2、str(dict)
作用:输出字典,以可打印的字符串表示。
b= {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
str(b) # "{'Name': 'Runoob', 'Class': 'First', 'Age': 7}"
3、type(variable)
返回输入的变量类型,如果变量是字典就返回字典类型。
b = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
type(b) # <class 'dict'>
6、字典存储底层原理
字典类型的数据是以散列的方法进行存储,用到的数为哈希函数。系统会创建一个连续的内存空间,一般该空间大小为2n,并对该内存空间进行标号处理,这种标号处理可以理解为数组的下标,从0开始,到 2n-1 结束。在进行键值对的存储时,会通过哈希函数把键转化为某一个二进制,然后查看n位二进制数与该数值相同的标号单元,如果无内容,则把该键值对放进;如果有内容(发生冲突),则取下一个n位(即第n到2n位)二进制数,在进行比较。为了保证发生冲突几率低,系统会在内存使用2/3的时候进行扩充,将已经存的数据放入到新扩充的内存中。
如果我们在字典中进行删除操作,有可能使本来发生冲突的那个存储单元现在不冲突了,就会产生一些问题。
集合
1、介绍
集合(set)是一个无序的不重复元素序列。
可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
创建格式:
parame = {value01,value02,...}
或者
set(value)
集合的一些特征与数学中的集合和c++STL中的集合特性是一样的,重复的元素只存在一个。集合有自动去重功能:
basket = {'apple', 'orange', 'apple', 'pear', 'orange', 'banana'}
print(basket) # {'orange', 'banana', 'pear', 'apple'}
2、相关操作
可以用成员运算符in/not in用于判断集合中是否有该元素
'orange' in basket # True
'crabgrass' in basket #False
当集合中为字符串时,自动变为单字符序列并进行自动去重工作
a = set('abracadabra')
b = set('alacazam')
a #{'a', 'r', 'b', 'c', 'd'}
集合的一些运算:
| 或运算,A|B:A集合和B集合所有的元素(去重)
&与运算,A&B:A集合和B集合都有的元素
^异或运算,A异或B,不同时在A和B中的元素
a - b # 集合a中包含而集合b中不包含的元素
{'r', 'd', 'b'}
a | b # 集合a或b中包含的所有元素
{'a', 'c', 'r', 'd', 'b', 'm', 'z', 'l'}
a & b # 集合a和b中都包含了的元素
{'a', 'c'}
a ^ b # 不同时包含于a和b的元素
{'r', 'd', 'b', 'm', 'z', 'l'}
3、集合元素的添加
语法:
s.add( x )
例子:
thisset = set(("Google", "Runoob", "Taobao"))
thisset.add("Facebook")
print(thisset) # {'Taobao', 'Facebook', 'Google', 'Runoob'}
还可以进行另一种添加方式,其中x可以有多个,用逗号分开
s.update( x )
例子:
thisset = set(("Google", "Runoob", "Taobao"))
thisset.update({1,3})
print(thisset) #{1, 3, 'Google', 'Taobao', 'Runoob'}
thisset.update([1,4],[5,6])
print(thisset) #{1, 3, 4, 5, 6, 'Google', 'Taobao', 'Runoob'}
>>>
4、移除元素
(1)随机删除
s.pop()
返回的是所删除元素的值
(2)普通删除
s.remove( x )
(3)清空集合
s.clear()