百万年薪python之路 -- 小数据池和代码块练习
1.请用代码验证 "alex" 是否在字典的值中?
info = {'name':'王刚蛋','hobby':'铁锤','age':'18',...100个键值对}
info = {'name':'王刚蛋','hobby':'铁锤','age':'123alex1123'} #假设有一百个键值对
flag = False
for i in info.values():
if "alex" in i:
flag = True
if flag:
print("alex是在字典的值中")
else:
print("alex不在字典的值中")
2.有如下
v1 = {'郭宝元','李杰','太白','梦鸽'}
v2 = {'李杰','景女神}
请得到 v1 和 v2 的交集并输出
print(v1 & v2)
请得到 v1 和 v2 的并集并输出
print(v1 | v2)
请得到 v1 和 v2 的 差集并输出
print(v1 - v2)
请得到 v2 和 v1 的 差集并输出
print(v2 - v1)
3.循环提示用户输入,并将输入内容追加到列表中(如果输入N或n则停止循环)
lst = []
while 1:
inp = input("请输入内容:")
if inp.upper() == "N":
break
else:
lst.append(inp)
print(lst)
4.写代码实现
v1 = {'alex','武sir','黑哥'}
v2 = []
循环提示用户输入,如果输入值在v1中存在,则追加到v2中,如果v1中不存在,则添加到v1中。(如果输入N或n则停止循环)
v1 = {'alex','武sir','黑哥'}
v2 = []
while 1:
inp = input("请输入内容:")
if inp.upper() != "N":
if inp in v1:
v2.append(inp)
else:
v1.add(inp)
else:
break
print("v1:",v1)
print("v2",v2)
5.判断以下值那个能做字典的key ?那个能做集合的元素?
1
可以作字典的key
可以作集合的元素
-1
可以作字典的key
可以作集合的元素
""
可以作字典的key
可以作集合的元素
None
可以作字典的key
可以作集合的元素
[1,2]
不可以作字典的key
不可以作集合的元素
(1,)
可以作字典的key
可以作集合的元素
{11,22,33,4}
不可以作字典的key
不可以作集合的元素
{'name':'wupeiq','age':18}
不可以作字典的key
不可以作集合的元素
6.is 和 == 的区别?
== 判断等号两边值是否相等
is 判断两边的值内存地址是否相等
7.type使用方式及作用?
使用方式:type(被测的数据类型)
作用:判断被测的数据类型是什么数据类型
8.id的使用方式及作用?
使用方式:id(被测的数据)
作用:写出被测的数据的内存地址
9.看代码写结果并解释原因
v1 = {'k1':'v1','k2':[1,2,3]}
v2 = {'k1':'v1','k2':[1,2,3]}
result1 = v1 == v2
result2 = v1 is v2
print(result1)
print(result2)
True
False
原因:
v1 和 v2不是指向同一个内存地址
在小数据池中只有整数,字符串,布尔值这三个数据类型符合缓存机制,而字典不符合.
10.看代码写结果并解释原因
v1 = {'k1':'v1','k2':[1,2,3]}
v2 = v1
result1 = v1 == v2
result2 = v1 is v2
print(result1)
print(result2)
True
True
原因:
因为v1和v2是指向同一个内存地址
11.看代码写结果并解释原因
v1 = {'k1':'v1','k2':[1,2,3]}
v2 = v1
v1['k1'] = 'wupeiqi'
print(v2)
{'k1': 'wupeiqi','k2':[1,2,3]}
原因:
因为v1和v2是指向同一个内存地址,是同一个
12.看代码写结果并解释原因
v1 = '人生苦短,我用Python'
v2 = [1,2,3,4,v1]
v1 = "人生苦短,用毛线Python"
print(v2)
[1,2,3,4,'人生苦短,我用Python']
原因:
v1 指向了另一块内存地址,但v2指向的 '人生苦短,我用Python'没有变
13.看代码写结果并解释原因
info = [1,2,3]
userinfo = {'account':info, 'num':info, 'money':info}
info.append(9)
print(userinfo)
info = "题怎么这么多"
print(userinfo)
{'account':[1,2,3,9], 'num':[1,2,3,9], 'money':[1,2,3,9]}
{'account':[1,2,3,9], 'num':[1,2,3,9], 'money':[1,2,3,9]}
原因:
第一个输出 因为开辟空间后,info在第二层内存地址进行了修改,所以userinfo也发生了改变
第二个输出 因为info指向了另一个内存地址,但userinfo没有发生改变
14.看代码写结果并解释原因
info = [1,2,3]
userinfo = [info,info,info,info,info]
info[0] = '不仅多,还特么难呢'
print(info,userinfo)
['不仅多,还特么难呢',2,3][['不仅多,还特么难呢',2,3],['不仅多,还特么难呢',2,3],['不仅多,还特么难呢',2,3],['不仅多,还特么难呢',2,3],['不仅多,还特么难呢',2,3]]
原因:
因为info[0]发生了改变,所以info为['不仅多,还特么难呢',2,3]
因为info[0]是第二层可变数据,修改后,源数据也会发生改变
15.看代码写结果并解释原因
info = [1,2,3]
userinfo = [info,info,info,info,info]
userinfo [2] [0] = '闭嘴'
print(info,userinfo)
[ '闭嘴',2,3][[ '闭嘴',2,3],[ '闭嘴',2,3],[ '闭嘴',2,3],[ '闭嘴',2,3],[ '闭嘴',2,3]]
原因:
因为userinfo [2] [0] 发生了改变,所以info[0]为"闭嘴"
因为userinfo [2] [0] 是第二层可变数据,修改后,源数据也会发生改变
16.看代码写结果并解释原因
info = [1,2,3]
user_list = []
for item in range(10):
user_list.append(info)
info[1] = "是谁说Python好学的?"
print(user_list)
[[1,"是谁说Python好学的?",3],[1,"是谁说Python好学的?",3],[1,"是谁说Python好学的?",3],[1,"是谁说Python好学的?",3],[1,"是谁说Python好学的?",3],[1,"是谁说Python好学的?",3],[1,"是谁说Python好学的?",3],[1,"是谁说Python好学的?",3],[1,"是谁说Python好学的?",3],[1,"是谁说Python好学的?",3]]
原因:
因为for循环10次,所以有九个列表
因为info是可变数据类型,又因为在第二层内存地址,所以info发生改变
17.看代码写结果并解释原因
data = {}
for i in range(10):
data['user'] = i
print(data)
{"user":9}
原因:
for循环前9次都被覆盖,最后"user"的值是9
18.看代码写结果并解释原因
data_list = []
data = {}
for i in range(10):
data['user'] = i
data_list.append(data)
print(data)
{"user":9}
原因:
for循环前9次都被覆盖,最后"user"的值是9
19.看代码写结果并解释原因
data_list = []
for i in range(10):
data = {}
data['user'] = i
data_list.append(data)
print(data_list)
[{'user':1},{'user':2},{'user':3},{'user':4},{'user':5},{'user':6},{'user':7},{'user':8},{'user':0}]
原因:
for循环的每一次循环都往date字典中加入一个键值对,然后追加到date_list里,但每次循环date被重新赋值成{},所以追加九次,且字典的值为0~9
20.使用循环打印出一下效果:
*
**
***
****
*****
****
***
**
*
*
***
*****
*******
*********
for i in range(1,6):
print("*" * i)
for i in range(4,0,-1):
print("*" * i)
for i in range(1,10,2):
print("*" * i)
21.敲七游戏. 从1开始数数. 遇到7或者7的倍数(不包含17,27,这种数)要在桌上敲⼀下. 编程来完成敲七. 给出⼀个任意的数字n. 从1开始数. 数到n结束. 把每个数字都放在列表中, 在数的过程中出现7或者7的倍数(不包含17,27,这种数).则向列表中添加⼀个'咣'
例如, 输⼊10. lst = [1, 2, 3, 4, 5, 6, '咣', 8, 9, 10]
lst = []
inp = input("请输入一个整数:")
if inp.isdecimal() and int(inp) > 0:
for i in range(1,int(inp) + 1):
if i % 7 != 0:
lst.append(i)
else:
lst.append("咣")
print(lst)
else:
print("输入错误!")
百万年薪python之路 -- 小数据池和代码块练习的更多相关文章
- 百万年薪python之路 -- 小数据池和代码块
1.小数据池和代码块 # 小数据池 -- 缓存机制(驻留机制) # == 判断两边内容是否相等 # a = 10 # b = 10 # print(a == b) # is 是 # a = 10 # ...
- python基础之小数据池、代码块、编码和字节之间换算
一.代码块.if True: print(333) print(666) while 1: a = 1 b = 2 print(a+b) for i in '12324354': print(i) 虽 ...
- python基础之小数据池、代码块、编码
一.代码块.if True: print(333) print(666) while 1: a = 1 b = 2 print(a+b) for i in '12324354': print(i) 虽 ...
- Python小数据池,代码块
今日内容一些小的干货 一. id is == 二. 代码块 三. 小数据池 四. 总结 python小数据池,代码块的最详细.深入剖析 一. id is == 二. 代码块 三. 小数据池 四. ...
- python 小数据池,代码块, is == 深入剖析
python小数据池,代码块的最详细.深入剖析 一. id is == 二. 代码块 三. 小数据池 四. 总结 一,id,is,== 在Python中,id是什么?id是内存地址,那就有人问了, ...
- Python 小数据池和代码块缓存机制
前言 本文除"总结"外,其余均为认识过程:3.7.5: 总结: 如果在同一代码块下,则采用同一代码块下的缓存机制: 如果是不同代码块,则采用小数据池的驻留机制: 需要注意的是,交互 ...
- python之路--小数据池,再谈编码,is和 == 的区别
一 . 小数据池 # 小数据池针对的是: int, str, bool 在py文件中几乎所有的字符串都会缓存. # id() 查看变量的内存地址 s = 'attila' print(id(s)) 二 ...
- python小数据池,代码块知识
一.什么是代码块? 根据官网提示我们可以获知: A Python program is constructed from code blocks. A block is a piece of Pyth ...
- python小数据池,代码块的最详细、深入剖析
代码块: Python程序是由代码块构造的.块是 一个python程序的文本,他是作为一个单元执行的. 代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块. 而作为交互方式输入的每个命令都是 ...
随机推荐
- DOM之节点操作
DOM提供了很多实用的API,这些API让我们可以轻松的访问HTML文档.所谓API(应用程序接口),简单来说,就是让我们可以直接使用它访问程序的一些属性或方法,而不用了解程序内部的运作过程和原理. ...
- App的功能测试要点
一 UI测试 (1)界面(菜单.窗口.按钮)布局.风格是否满足客户要求,文字和图片组合是否美观,操作是否友好. (2)清晰.简洁.美观.响应.一致 (3)图形测试.内容测试.导航测试 (图形包括 ...
- spring定时任务-文件上传进度条
spring定时任务 导依赖 <!-- https://mvnrepository.com/artifact/org.quartz-scheduler/quartz --> <dep ...
- JAVASE知识点总结(四)
第十七章:内部类和枚举 一.内部类 1.什么是内部类? 2.为什么要有内部类? 3.内部类的种类: 5.实例内部类 6.创建实例内部类 7.实例内部类注意点 8.访问变量原则: 4 9.静态内部类: ...
- springboot系列之02-需要了解的宏观知识点
未经允许,不得转载 原作者:字母哥博客 本文完整系列出自:springboot深入浅出系列 一.Spring Boot . Spring MVC .Spring对比 首先你需要明白一件事情:Sprin ...
- Enum枚举的使用实现
业务中涉及到的状态字段或者简单的选择项的使用. 例如: 1.定义enum枚举类. package com.yjl.enums; import java.util.Objects; public enu ...
- uC/OS-III 时钟节拍(一)
时钟节拍就是操作系统的时基,操作系统要实现时间上的管理,必须依赖于时基(时基即时间基准,操作系统的基准时钟). uC/OS-III时钟节拍的实现过程 时钟节拍就是系统以固定的频率产生中断(时基中断), ...
- 高效解决「SQLite」数据库并发访问安全问题,只这一篇就够了
Concurrent database access 本文译自:https://dmytrodanylyk.com/articles/concurrent-database/ 对于 Android D ...
- Apache Kylin 概述
1 Kylin是什么 今天,随着移动互联网.物联网.AI等技术的快速兴起,数据成为了所有这些技术背后最重要,也是最有价值的"资产".如何从数据中获得有价值的信息?这个问题驱动了相关 ...
- 使用jsr303实现数据校验
除了前端的js验证,服务端也可加入数据验证,springmvc中有两种方式可以验证输入 利用spring自带的验证框架 利用jsr303实现 jsr303实现数据校验 jsr303是java为bean ...