37-畅想第三次作业

利用周末时间,学习字典和集合
字典的介绍
举个例子,假设要根据同学的名字查找对应的成绩
用字典实现,只需要一个“名字”-“成绩”的对照表,直接根据名字查找成
绩,无论这个表有多大,查找速度都不会变慢。

d = {‘Michael’: 95, ‘Bob’: 75, ‘Tracy’: 85}
字典以键值对形式出现,一个key对应一个value

字典的遍历
通过 for … in … 我们可以遍历字符串、列表、元组、字典等

  1. 遍历字典的key
    d1 = {‘name’:‘abc’,‘age’:‘18’, ‘class’:‘cnh’}
    for key in d1:
    print(key)
    结果:
    name
    age
    class
  2. 遍历字典的value
    d1 = {‘name’:‘abc’,‘age’:‘18’, ‘class’:‘cnh’}
    for value in d1.values():
    print(value)
    结果:
    abc
    18
    cnh
  3. 遍历字典的项
    d1 = {‘name’:‘abc’,‘age’:‘18’, ‘class’:‘cnh’}
    for item in d1.items():
    print(item)
    结果:
    (‘name’, ‘abc’)
    (‘age’, ‘18’)
    (‘class’, ‘cnh’)
  4. 遍历字典的key-value
    for key,value in d1.items():
    print(‘key=%s,value=%s’%(key,value))
    结果:
    key=name,value=abc
    key=age,value=18
    key=class,value=cnh
    enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合
    为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中。

chars = [‘a’, ‘b’, ‘c’, ‘d’]
for i, chr in enumerate(chars):
print i, chr

字典的常见操作

  1. 修改元素
    字典的每个元素中的数据是可以修改的,只要通过 key 找到,即可修改
    info = {‘name’:‘kkb’, ‘id’:100, ‘sex’:‘f’, ‘address’:‘中国北京’}
    new_id = input(‘请输入新的学号:’)
    info[‘id’] = int(new_id)
    print(‘修改之后的id为: %d’ % info[‘id’])

  2. 添加元素
    访问不存在的元素
    info = {‘name’:‘kkb’, ‘sex’:‘f’, ‘address’:‘中国北京’}
    print(‘id为:%d’ % info[‘id’])

  3. 删除元素
    对字典进行删除操作,有以下几种:
    del
    clear()
    del 删除指定的元素
    info = {‘name’:‘kkb’, ‘sex’:‘f’, ‘address’:‘中国北京’}
    print(‘删除前,%s’ % info[‘name’])
    del info[‘name’]
    print(‘删除后,%s’ % info[‘name’])

del 删除整个字典
info = {‘name’:‘monitor’, ‘sex’:‘f’, ‘address’:‘China’}
print(‘删除前,%s’ % info)
del info
print(‘删除后,%s’ % info)
clear 清空整个字典
info = {‘name’:‘monitor’, ‘sex’:‘f’, ‘address’:‘China’}
print(‘清空前,%s’ % info)
info.clear()
print(‘清空后,%s’ % info)
4. len()
测量字典中,键值对的个数
d1 = {‘name’:‘abc’,‘age’:‘18’, ‘class’:‘cnh’}
print(len(d1))

  1. keys

返回一个包含字典所有 key 的列表
d1 = {‘name’:‘abc’,‘age’:‘18’, ‘class’:‘cnh’}
print(list(d1.keys()))
结果:
[‘name’, ‘age’, ‘class’]
6. values
返回一个包含字典所有 value 的列表
d1 = {‘name’:‘abc’,‘age’:‘18’, ‘class’:‘cnh’}
print(list(d1.values()))
结果:
[‘abc’, ‘18’, ‘cnh’]
7. items
返回一个包含所有(键,值)元祖的列表
d1 = {‘name’:‘abc’,‘age’:‘18’, ‘class’:‘cnh’}
print(list(d1.items()))
结果:
[(‘name’, ‘abc’), (‘age’, ‘18’), (‘class’, ‘cnh’)]
8. has_key (Python3 已取消)
dict.has_key(key) 如果key在字典中,返回 True ,否则返回 False

判断语句和循环语句

  1. if语句
    计算机之所以能做很多自动化的任务,因为它可以自己做条件判断。
    例如,输入用户年龄,根据年龄打印不同的内容,在Python程序中,用 if 语句
    实现:
    age = 20
    if age >= 18:
    print(‘your age is’, age)
    print(‘adult’)
    根据Python的缩进规则,如果 if 语句判断是 True ,就把缩进的两个print语句
    执行了,否则,什么也不做。
    也可以给 if 添加一个 else 语句,意思是,如果 if 判断是 False ,不要执
    行 if 的内容,去把 else 执行了:
    age = 3
    if age >= 18:
    print(‘your age is’, age)
    print(‘adult’)
    else:
    print(‘your age is’, age)
    print(‘teenager’)
    注意不要少写了冒号 : 。
    当然上面的判断是很粗略的,完全可以用 elif 做更细致的判断:
    age = 3
    if age >= 18:
    print(‘adult’)
    判断语句和循环语句
    46
    elif age >= 6:
    print(‘teenager’)
    else:
    print(‘kid’)
    elif 是 else if 的缩写,完全可以有多个 elif ,所以 if 语句的完整形式
    就是:
    if <条件判断1>:
    <执行1>
    elif <条件判断2>:
    <执行2>
    elif <条件判断3>:
    <执行3>
    else:
    <执行4>
    if 语句执行有个特点,它是从上往下判断,如果在某个判断上是 True ,把
    该判断对应的语句执行后,就忽略掉剩下的 elif 和 else ,所以,请测试并
    解释为什么下面的程序打印的是 teenager :
    age = 20
    if age >= 6:
    print(‘teenager’)
    elif age >= 18:
    print(‘adult’)
    else:
    print(‘kid’)

  2. 循环
    我们来试想这样一种情况,现在让你们在控制台输出100条 hello world ,本质上,
    我们写几百条 print 函数输出就可以了,但是如果一千条一万条呢.这就要用到
    循环语句了.
    (1) while 循环
    while循环语句语法
    while 条件:
    条件满足时,做的事情1
    条件满足时,做的事情2
    判断语句和循环语句
    49
    条件满足时,做的事情3
    …(省略)…
    例如输出100条 helloworld
    i = 100
    whiel i <=100
    print(‘hello world’)
    i + 1
    相对应,在whiel循环语句,每执行一次循环语句, i 就会加1,直到 i 等于101
    时不满足
    i<=100 的条件,循环就结束了
    (2) for循环
    for循环和while一样同样可以进行循环,并且是运行最多的循环⽅式,⽽且它有⼀
    项⾮常厉害的功能—— 遍历 ,在Python中 for 循环可以遍历任何序列项⽬,如字
    符串,或者今后会学到的列表,例如我们遍历字符串,就特指将字符串的所有字符全
    部访问一遍
    names = [‘Michael’, ‘Bob’, ‘Tracy’]
    for name in names:
    print(name)
    执行这段代码,会依次打印 names 的每一个元素:
    Michael
    Bob
    Tracy
    所以 for x in … 循环就是把每个元素代⼊变量 x ,然后执行缩进块的语
    句。

再比如我们想计算1-10的整数之和,可以用一个 sum 变量做累加:
sum = 0
for x in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]:
sum = sum + x
print(sum)
Python还提供了⼀个range()函数,可以配合我们的for循环使⽤,例如:
for i in range(5):
print(i)
#效果等同于 while 循环的:
i = 0
while i < 5:
print(i)
i += 1
我们在来学习两个关键字 breake continue ,这两个关键字是我们循环语句的
好帮手
break
在循环中, break 语句可以提前退出循环。例如,本来要循环打印1~100的数
字:
n = 1
while n <= 100:
print(n)
n = n + 1
print(‘END’)
上⾯的代码可以打印出1~100。
如果要提前结束循环,可以用 break 语句:
判断语句和循环语句
51
n = 1
while n <= 100:
if n > 10: # 当n = 11时,条件满足,执行break语句
break # break语句会结束当前循环
print(n)
n = n + 1
print(‘END’)
执行上面的代码可以看到,打印出1~10后,紧接着打印 END ,程序结束。
可见 break 的作用是提前结束循环。
continue
在循环过程中,也可以通过 continue 语句,跳过当前的这次循环,直接开始
下一次循环。
n = 0
while n < 10:
n = n + 1
print(n)
上面程序可以打印出1~10。但是,如果我们想只打印奇数,可以
用 continue 语句跳过某些循环:
n = 0
while n < 10:
n = n + 1
if n % 2 == 0: # 如果n是偶数,执行continue语句
continue # continue语句会直接继续下⼀轮循环,后续的print()语句
不会执行
print(n)
执行上面的代码可以看到,打印的不再是1~10,而是1,3,5,7,9。
可见 continue 的作用是提前结束本轮循环,并直接开始下一轮循环。
判断语句和循环语句

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值