文章目录
字典
1、字典是“键值对”的无序可变序列,字典中的每个元素都是一个“键值对”,包含“键对象”和“值对象”。可以通过“键对象”实现快速获取,删除,更新对应的“值对象”。
2、列表中我们通过“下标数字”找到对应的对象。字典中通过“键对象”找到对应的“值对象”。“键”是任意的不可变数据,比如:整数、浮点数、字符串、元组。但是:列表、字典、集合这些可变对象,不能作为“键”。并且“键”不可重复。
3、典型字典定义:a={‘name’:‘hanshao’,‘age’:18,‘job’:‘teacher’}
字典的创建
1、我们可以通过{}、dict()来创建字典对象
>>> a={"name":"shaohan","age":18,"dd":[3,4,5]}
>>> a
{'name': 'shaohan', 'age': 18, 'dd': [3, 4, 5]}
>>> b=dict(name="shaohan",age=18)
>>> b
{'name': 'shaohan', 'age': 18}
>>> b=[("name","shaohan"),("age",18)]
>>> b
[('name', 'shaohan'), ('age', 18)]
>>> c={} #空的字典对象
>>> c
{}
>>> d=dict() #空的字典对象
>>> d
{}
2、通过zip()创建字典对象
>>> k=['name','age','job']
>>> v=['shaohan',18,'teacher']
>>> d=dict(zip(k,v))
>>> d
{'name': 'shaohan', 'age': 18, 'job': 'teacher'}
3、通过fromkeys创建值为空的字典
>>> a=dict.fromkeys(['name','age','job'])
>>> a
{'name': None, 'age': None, 'job': None}
字典元素的访问
1、通过[键]获得“值”。若键不存在,则抛出异常。
>>> a={"name":"shaohan","age":18,"job":'teacher'}
>>> a['name']
'shaohan'
>>> a['sex']
Traceback (most recent call last):
File "<pyshell#23>", line 1, in <module>
a['sex']
KeyError: 'sex'
2、通过get()方法获得“值”,推荐使用,优点:指定键不存在,返回None;也可以设定指定键不存在时默认返回的对象。推荐使用get()获取“值对象”
>>> a.get('name')
'shaohan'
>>> a.get('sex')
>>> a
{'name': 'shaohan', 'age': 18, 'job': 'teacher'}
>>> print(a.get('sex'))
None
>>> a.get('sex','女')
'女'
3、列出所有的键值对
>>> a.items()
dict_items([('name', 'shaohan'), ('age', 18), ('job', 'teacher')])
4、列出所有的键,列出所有的值
>>> a.keys()
dict_keys(['name', 'age', 'job'])
>>> a.values()
dict_values(['shaohan', 18, 'teacher'])
5、len()键值对的个数
>>> len(a)
3
6、检测一个键是否在字典里
>>> a={'name':'shaohan','age':18}
>>> 'name' in a
True
字典元素的添加、修改、删除
1、给字典新增的“键值对”。如果“键”已经存在,则覆盖旧的键值对;如果‘’键“”不存在,则新增“键值对”。
>>> a={"name":"shaohan","age":18,"job":'teacher'}
>>> a['address']='西三旗1号'
>>> a
{'name': 'shaohan', 'age': 18, 'job': 'teacher', 'address': '西三旗1号'}
>>> a['age']=20
>>> a
{'name': 'shaohan', 'age': 20, 'job': 'teacher', 'address': '西三旗1号'}
2、使用update() 将新字典中所有键值对全部添加到旧字典对象上。如果key有重复,则直接覆盖。
>>> a={"name":"shaohan","age":18,"job":'teacher'}
>>> b={"name":"gaoqiqi","sex":"男","address":"西三旗1号"}
>>> a.update(b)
>>> a
{'name': 'gaoqiqi', 'age': 18, 'job': 'teacher', 'sex': '男', 'address': '西三旗1号'}
>>>
3、字典中元素的删除,可以使用del()方法;或者clear() 删除所有键值对;pop() 删除指定键值对,并返回对应的“值对象”;
>>> a={"name":"shaohan","age":18,"job":'teacher'}
>>> del(a["name"])
>>> a
{'age': 18, 'job': 'teacher'}
>>> b=a.pop("age")
>>> b
18
>>> a.clear()
>>> a
{}
4、popitem():随机删除和返回该键值对。字典是“无序可变序列”,因此没有第一个元素,最后一个元素的概念;popitem弹出随机的项,因为字典没有“最后元素”或者其他有关顺序的概念。若想一个接一个地移除并处理项,这个方法就有效。(不用首先获取键的列表)
>>>a={"name":"shaohan","age":18,"job":'teacher'}
>>> a.popitem()
('job', 'teacher')
>>> a
{'name': 'shaohan', 'age': 18}
>>> a.popitem()
('age', 18)
>>> a
{'name': 'shaohan'}
序列解包
序列解包可以用于元组、列表、字典。序列解包可以让我们方便对多个变量赋值。
>>> x,y,z=20,30,10
>>> x
20
>>> x,y,z=(10,20,30)
>>> (a,b,c)=(10,20,30)
>>> a
10
>>> b
20
序列解包用于字典时,默认是对“键”进行操作;如果需要对键值对操作,则需要使用items();如果需要对“值”进行操作,则需要使用values();
>>> s={'name':'shanhan','age':19,'job':'teacher'}
>>> a,b,c=s
>>> a
'name'
>>> b
'age'
>>> c
'job'
>>> e,d,f=s.values()
>>> e
'shanhan'
>>> d
19
>>> f
'teacher'
>>> h,i,g=s.items()
>>> h
('name', 'shanhan')
>>> i
('age', 19)
>>> g
('job', 'teacher')
表格数据使用字典和列表存储,并实现访问
| 姓名 | 年龄 | 薪资 | 城市 |
|---|---|---|---|
| 张三 | 18 | 10000 | 北京 |
| 李四 | 19 | 20000 | 深圳 |
| 王五 | 20 | 30000 | 上海 |
{"name":"张三","age":18,"salary":10000,"city":"北京"}
r2={"name":"李四","age":19,"salary":20000,"city":"深圳"}
r3={"name":"王五","age":20,"salary":30000,"city":"上海"}
tb=[r1,r2,r3]
print(tb[1].get("salary"))
for i in range (len(tb)):
print(tb[i].get("salary"))
for i in range(len(tb)):
print(tb[i].get("name"),tb[i].get("age"),tb[i].get("salary"),tb[i].get("city"))
输出结果如下:
20000
10000
20000
30000
张三 18 10000 北京
李四 19 20000 深圳
王五 20 30000 上海
字典核心底层原理(重要)
字典对象的核心是散列表。散列表是一个稀疏数组(总是有空白元素的数组),数组的每个单元叫做bucket。每个bucket有两部分:一个是键对象的引用,一个是值 对象的引用。
由于所有bucket结构和大小一致,我们可以通过偏移量来读取指定bucket。
将一个键值对放进字典的底层进程
1、假设字典a对象创建完后,数组长度为8。
>>> a={}
>>> a["name"]="hanshao"
2、我们要把“name”=“hanshao”这个键值对放到字典对象a中,首先第一步需要计算键“name”的散列值。Python中可以通过hash()来计算。
>>> bin(hash("name"))
'0b110011111100011000111010100111010000110100010101111011100011001'
3、由于数组长度为8,我们可以拿出计算出的散列值的最右边3位数字作为偏移量,即“101”,十进制是数字5。我们查看偏移量5,对应的bucket是否为空。如果为空,则将键值对放进去。如果不为空,则依次取右边3位作为偏移量,即“100”,十进制是数字。
4、再查看偏移量为4的bucket是否为空,直到找到为空的bucker将键值对放进去。
根据键查找“键值对”的底层过程
1、当我们调用a.get(“name”),就是根据键查找到“键值对”,从而找到值对象。
2、同上,计算“name”对象的散列值。
>>> bin(hash("name"))
'0b110011111100011000111010100111010000110100010101111011100011001'
3、依次取散列值的不同数字的位置的数字,假设数组长度为8,我们可以拿计算出的散列表的最右边3位数字作为偏移量,即“101”,十进制是数字5,我们查看偏移量5,对应的bucker是否为空,如果为空,则返回None。如果不为空,则将这bucker的键对象计算对应散列值,和我们的散列值进行比较,如果相等,则将对应“值对象”返回,如果不相等,则再依次取其他几位数字,重新计算偏移量。依次取完后,仍没有找到,则返回None。
用法总结
1、键必须可散列
(1) 数字、字符串、元组,都是可散列的
(2)自定义对象需要支持下面三点:
a、 支持hash()函数 b、支持通过__eq__()方法 检验相等性。c、若a==b为真,则hash(a)==hash(b)也为真。
2、字典在内存中开销巨大,典型的空间换时间。
3、键查询速度很快。
4、往字典里添加新建可能导致扩容,导致散列表中键的次序变化。因此,不要在遍历字典的同时进行字典的修改。
集合
集合是无序可变,元素不能重复。集合底层是字典实现,集合的所有元素都是字典中的“键对象”,因此是不能重复的且唯一的。
集合创建和删除
1、使用{}创建集合对象,并使用add() 方法添加元素
>>> a={3,4,7}
>>> a
{3, 4, 7}
>>> a.add(9)
>>> a
{9, 3, 4, 7}
2、使用set() ,将列表、元组等可迭代对象转换为集合。如果原来数据存在重复数据,则只保留一个。
>>> a=['a','c','b','e']
>>> b=set(a)
>>> b
{'b', 'a', 'c', 'e'}
3、remove() 删除指定元素,clear()清空整个集合
>>> a={10,20,30,40,50}
>>> a.remove(30)
>>> a
{40, 10, 50, 20}
>>> a.clear()
>>> a
set()
4、集合相关操作
>>> a={1,2,3,'sxt'}
>>> b={2,3,4,'set'}
>>> a|b #并集
{1, 2, 3, 4, 'sxt', 'set'}
>>> a&b #交集
{2, 3}
>>> a-b #差集
{'sxt', 1}
>>> a.union(b) #并集
{1, 2, 3, 4, 'sxt', 'set'}
>>> a.intersection(b) #交集
{2, 3}
>>> a.difference(b) #差集
{'sxt', 1}
选择结构
选择结构通过判断条件是否成立,来决定执行哪个分支。选择结果有多种形式,分为:单分支,双分支,多分支。
单分支结构
if语句单分支结构的语法形式如下:
if条件表达式:
语句/语句块
其中
1、条件表达式:可以是逻辑表达式,关系表达式,算术表达式等等。
2、语句/语句块:可以是一条语句,也可以是多条语句,多条语句缩进必须对其一致。
输入一个数字,小于10,则打印这个数字
a = input("请输入一个小于10的数字:")
if int(a)<10:
print(a)
条件表达式
在选择和循环结构中,条件表达式的值为False的情况下:
False、0、0.0、空值None、空序列对象(空列表、空元组、空集合、空字典、空字符串)、空range对象、空迭代对象。
其他情况均为True。
测试各种条件表达式
if 3: #整数作为条件表达式
print("ok")
a=[] # 列表作为条件表达式,由于为空列表,是False
if a:
print("空列表,False")
s="False" #非空字符串,是True
if s:
print("非空字符串,是True")
c=9
if 3<c<20:
print("3<c<20")
if 3<c and c<20:
print("3<c and c<20")
if True: #布尔值
print("True")
条件表达式中,不能有赋值操作符“=”
在python中,条件表达式不能出现赋值操作符“=”。如下列代码会报语法错误:
if 3<c and (c=20):
print(“赋值符不能出现在条件表达式中”)
双分支结构
双分支结构的语法如下:
if 条件表达式:
语句1/语句块1
else:
语句2/语句块2
输入一个数字,小于10,则打印该数字;大于10,则打印“数字太大”
num = input ("输入一个数字:")
if int(num)<10:
print(num)
else:
print("输入错误")
三元条件运算符
三元条件运算符语法如下:
条件为真时 if (条件表达式)else 条件为假的值
num = input("请输入一个数字:")
print("num是大于20的数字" if int(num)>20 else "输入错误")
多分支结构
多分支选择结构的语法结构如下:
if 条件表达式1:
语句1/语句块1
elif 条件表达式2:
语句2/语句块2
.
.
elif 条件表达式n:
语句n/语句块n
[else:
语句n+1/语句块n+1
]
注意 多分支结构,几个分支之间是有逻辑关系的,不能随意颠倒顺序。
输入一个学生的成绩,将其转化成简单描述:不及格(小于60)、及格(60-79)、良好(80-89)、优秀(90-100)。
方法一(多分支结构)
score = int(input("请输入一个分数:"))
grade = ""
if score < 60:
grade = "不及格"
elif score < 80: #60-80之间
grade = "及格"
elif score < 90:
grade = "良好"
elif score <= 100:
grade = "优秀"
print("分数是{0},等级是{1}".format(score, grade))
方法二(使用完整的条件表达)
score = int(input("请输入分数"))
grade =""
if(score<60):
grade = "不及格"
if(60<=score<80):
grade = "及格"
if(80<=score<90):
grade = "良好"
if(90<=score<=100):
grade = "优秀"
print("分数是{0},等级是{1}".format(score, grade))
已知点的坐标(x,y),判断其所在象限
x=int(input("请输入x坐标"))
y=int(input("请输入y坐标"))
if(x==0 and y==0):print("原点")
elif(x==0):print("y轴")
elif(y==0):print("x轴")
elif(x>0 and y>0):print("第一象限")
elif(x<0 and y>0):print("第二象限")
elif(x<0 and y<0):print("第三象限")
else:
print("第四象限")
选择结构的嵌套
选择结构可以嵌套,使用时一定要注意控制好不同级别代码块的缩进量,因为缩进量决定代码的从属关系。
输入一个分数,分数在0-100之间,90以上是A,80以上是B,70以上是C,60以上是D,60以下是E。
方法一
score = int(input("请输入一个分数"))
if score>100 or score<0:
score = int(input("输入错误,请重新输入"))
else:
if score>=90:
grade = "A"
elif score>=80:
grade = "B"
elif score>=70:
grade = "C"
elif score>=60:
grade = "D"
else:
grade = "E"
print("分数为{0},等级为{1}".format(score,grade))
方法二
score =int(input("请输入一个分数"))
degree = "ABCDE"
num = 0
if score >100 or score <0:
print("请输入一个0-100的分数")
else:
num = score//10
if num < 6:
num = 5
print(degree[9-num])
循环结构
循环结构用来重复执行一条或多条语句。
表达逻辑为:如果符合条件,则反复执行循环体的语句。在每次执行完后都会判断一次条件是否为Ture,如果为Ture则重复执行循环体里的语句。
循环体里的语句至少应该包含改变条件表达式的语句,以使循环趋于结束;否则就会变成一个死循环。
while循环
while循环的语法格式如下:
while 条件表达式:
循环体语句
利用while循环打印从0-10的数字。
while num<=10:
print(num,end='\t')
num+=1
利用while循环,计算1-100之间数字的累加和,计算1-100之间偶数的累加和,计算1-100之间奇数的累加和。
num = 0
sum_all = 0
sum_even = 0
sum_odd = 0
while num<=100:
sum_all = sum_all + num
if num%2==0:sum_even += num
else:sum_odd += num
num +=1 #迭代,改变条件表达式,使循环趋于结束
print("1-100所有数的累加和:",sum_all)
print("1-100偶数的累加和:",sum_even)
print("1-100奇数的累加和:",sum_odd)
本文详细介绍了Python中的字典、集合及其操作,包括字典的创建、访问、修改和删除,以及集合的创建和删除。此外,文章还深入探讨了选择结构,包括单分支、双分支、多分支结构,并展示了如何在实际问题中应用这些概念。同时,讲解了循环结构中的while循环,给出了实例以帮助理解。
 循环结构(while循环)&spm=1001.2101.3001.5002&articleId=105278109&d=1&t=3&u=a923443848404c97ad597bdfd3540c9b)
1392

被折叠的 条评论
为什么被折叠?



