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之路 -- 小数据池和代码块练习的更多相关文章

  1. 百万年薪python之路 -- 小数据池和代码块

    1.小数据池和代码块 # 小数据池 -- 缓存机制(驻留机制) # == 判断两边内容是否相等 # a = 10 # b = 10 # print(a == b) # is 是 # a = 10 # ...

  2. python基础之小数据池、代码块、编码和字节之间换算

    一.代码块.if True: print(333) print(666) while 1: a = 1 b = 2 print(a+b) for i in '12324354': print(i) 虽 ...

  3. python基础之小数据池、代码块、编码

    一.代码块.if True: print(333) print(666) while 1: a = 1 b = 2 print(a+b) for i in '12324354': print(i) 虽 ...

  4. Python小数据池,代码块

    今日内容一些小的干货 一. id is == 二. 代码块 三. 小数据池 四. 总结 python小数据池,代码块的最详细.深入剖析   一. id is == 二. 代码块 三. 小数据池 四. ...

  5. python 小数据池,代码块, is == 深入剖析

    python小数据池,代码块的最详细.深入剖析   一. id is == 二. 代码块 三. 小数据池 四. 总结 一,id,is,== 在Python中,id是什么?id是内存地址,那就有人问了, ...

  6. Python 小数据池和代码块缓存机制

    前言 本文除"总结"外,其余均为认识过程:3.7.5: 总结: 如果在同一代码块下,则采用同一代码块下的缓存机制: 如果是不同代码块,则采用小数据池的驻留机制: 需要注意的是,交互 ...

  7. python之路--小数据池,再谈编码,is和 == 的区别

    一 . 小数据池 # 小数据池针对的是: int, str, bool 在py文件中几乎所有的字符串都会缓存. # id() 查看变量的内存地址 s = 'attila' print(id(s)) 二 ...

  8. python小数据池,代码块知识

    一.什么是代码块? 根据官网提示我们可以获知: A Python program is constructed from code blocks. A block is a piece of Pyth ...

  9. python小数据池,代码块的最详细、深入剖析

    代码块: Python程序是由代码块构造的.块是 一个python程序的文本,他是作为一个单元执行的. 代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块. 而作为交互方式输入的每个命令都是 ...

随机推荐

  1. 【面试】我是如何在面试别人Redis相关知识时“软怼”他的

    事出有因 Redis是一个分布式NoSQL数据库,因其数据都存储在内存中,所以访问速度极快,因此几乎所有公司都拿它做缓存使用,所以Redis常被称为分布式缓存. 一次我的一个同事让我帮他看Redis相 ...

  2. JAVA设计模式-动态代理(Proxy)源码分析

    在文章:JAVA设计模式-动态代理(Proxy)示例及说明中,为动态代理设计模式举了一个小小的例子,那么这篇文章就来分析一下源码的实现. 一,Proxy.newProxyInstance方法 @Cal ...

  3. 主动降噪技术(ANC)的前生今世--原理仿真

    一 原理: 主动降噪就是通过反相检测麦克风的声音或噪声来减弱周围环境的噪声让扬声器出来的声音听起来更清晰.主动降噪技术的目标就是通过一个自适应滤波器把不想要的噪声反相从而把噪声约束到固定的范围内.该系 ...

  4. js运动基础2(运动的封装)

    简单运动的封装 先从最简单的封装开始,慢慢的使其更丰富,更实用. 还是上一篇博文的代码,在此不作细说. 需求:点击按钮,让元素匀速运动. <!DOCTYPE html> <html ...

  5. Win系统下使用命令链接MySQL数据库

    方法一: 1:打开[开始]>[运行]输入[cmd]单击[确定]后出现CMD命令黑色窗口,这就是我们说的CMD命令行 2:默认进入C盘,于是我们可以进入E盘,点击回车.因为我的数据库是存放在E盘的 ...

  6. Spring boot - 梳理 - 根本上说,Spring Boot项目只不过是一个普通的Spring项目,只是使用了Spring Boot的起步依赖和自动配置

    根本上说,Spring Boot项目只不过是一个普通的Spring项目,只是使用了Spring Boot的起步依赖和自动配置

  7. 【SQL server基础】SQL视图加密,永久隐藏视图定义的文本

    SQL可以对视图进行加密.也就是,可永久隐藏视图定义的文本. 注意   此操作不可逆.加密视图后,无法再修改它,因为无法再看到视图定义.如果需要修改加密视图,则必须删除它并重新创建另一个视图. 示例代 ...

  8. Mybatis-Plus学习.,简化你的开发,提升开发效率.

    Mybatis-Plus学习以及实践 简介 参考网址 开发环境 开始开发 - 配置pom.xml - Dao/Service/Entity - 基本方法 - 查询类 - 更新类 分页插件 - pom. ...

  9. JAVA的List接口的remove重载方法调用原理

    前言 说真的,平常看源码都是自己看完自己懂,很少有写出来的冲动. 但是在写算法的时候,经常用到java中各种集合,其中也比较常用到remove方法. remove有重载函数,分别传入参数是索引inde ...

  10. jetbrains全系列可用2018

    转自 https://blog.csdn.net/u014044812/article/details/78727496 仅记录前两种方法 1.授权服务器激活 优点:方便快捷 缺点:激活的人数多了就容 ...