day07补充-数据类型总结及拷贝
数据类型总结
按照存一个值 OR 多个值来分
- 字符串、整型、浮点型存一个值
- 列表、元组、字典、集合存多个值
按照有序 OR 无序来分
- 字符串、列表、元组是有序数据
- 字典、集合是无序数据
按照可变 OR 不可变来分
- 列表、字典、集合是可变数据类型
- 整型、浮点型、字符串是不可变数据类型
拷贝 && 浅拷贝 && 深拷贝&& .copy()
如果 l2 是 l1的拷贝对象,l1发生改变改变,则l2也会发生改变: 因为l1与l2指向同一个内存地址id,l1是可变数据类型,值变化时id不改变,因此l2跟着改变
l1 = ['a','b','c',['d','e','f']]
l2 = l1
l1.append('g')
print(f"l1内存地址为{id(l1)},打印值为{l1}")
print(f"l2内存地址为{id(l2)},打印值为{l2}")
l1内存地址为2068776007112,打印值为['a', 'b', 'c', ['d', 'e', 'f'], 'g']
l1内存地址为2068776007112,打印值为['a', 'b', 'c', ['d', 'e', 'f'], 'g']
浅拷贝:如果l2是l1的浅拷贝对象,l1内部的不可变数据发生改变,则l2不变,如果l1内部的可变对象发生改变,l2也会跟着改变
import copy
l1 = ['a','b','c',['d','e','f']]
l2 = l1.copy()
l1.append('g') # 改变l1中的不可变数据类型,l2不会改变
print(f"l1内存地址为{id(l1)},打印值为{l1}")
print(f"l2内存地址为{id(l2)},打印值为{l2}")
print('*'*80)
import copy
l1 = ['a','b','c',['d','e','f']]
l2 = l1.copy()
l1[3].append('g') # 改变l1中的可变数据类型,l2也会跟着改变
print(f"l1内存地址为{id(l1)},打印值为{l1}")
print(f"l2内存地址为{id(l2)},打印值为{l2}")
l1内存地址为2068778801352,打印值为['a', 'b', 'c', ['d', 'e', 'f'], 'g']
l2内存地址为2068778814984,打印值为['a', 'b', 'c', ['d', 'e', 'f']]
********************************************************************************
l1内存地址为2068778811720,打印值为['a', 'b', 'c', ['d', 'e', 'f', 'g']]
l2内存地址为2068778802376,打印值为['a', 'b', 'c', ['d', 'e', 'f', 'g']]
深拷贝:如果l2是l1的深拷贝对象,l1内部的不可变对象发生改变,则l2不变,如果l1内部的可变对象发生改变,l2也不会改变。即:l1的改变不会影响l2
import copy
l1 = ['a','b','c',['d','e','f']]
l2 = copy.deepcopy(l1)
l1.append('g') # 改变l1中的不可变数据类型,l2不会改变
print(f"l1内存地址为{id(l1)},打印值为{l1}")
print(f"l2内存地址为{id(l2)},打印值为{l2}")
print('*'*80)
import copy
l1 = ['a','b','c',['d','e','f']]
l2 = copy.deepcopy(l1)
l1[3].append('g') # 改变l1中的可变数据类型,l2不会改变
print(f"l1内存地址为{id(l1)},打印值为{l1}")
print(f"l2内存地址为{id(l2)},打印值为{l2}")
l1内存地址为2068778801992,打印值为['a', 'b', 'c', ['d', 'e', 'f'], 'g']
l2内存地址为2068778811464,打印值为['a', 'b', 'c', ['d', 'e', 'f']]
********************************************************************************
l1内存地址为2068778067016,打印值为['a', 'b', 'c', ['d', 'e', 'f', 'g']]
l2内存地址为2068776735112,打印值为['a', 'b', 'c', ['d', 'e', 'f']]
copy() 从结果上来看就是浅拷贝
l1 = ['a','b','c',['d','e','f']]
l2 = l1.copy()
l1.append('g') # 改变l1中的不可变数据类型,l2不会改变
print(f"l1内存地址为{id(l1)},打印值为{l1}")
print(f"l2内存地址为{id(l2)},打印值为{l2}")
print('*'*80)
l1 = ['a','b','c',['d','e','f']]
l2 = l1.copy()
l1[3].append('g') # 改变l1中的可变数据类型,l2也会跟着改变
print(f"l1内存地址为{id(l1)},打印值为{l1}")
print(f"l2内存地址为{id(l2)},打印值为{l2}")
猜年龄游戏
附加一个猜年龄的小游戏,再接再厉....
"""
功能:登录用户猜年龄
作者:前辈眼中的小白
日期: 2019/5/25
"""
real_age = 23 # 给定正确的年龄
login_count = 0 # 控制登录次数
count = 0 # 控制猜游戏的次数
get_prize = [] # 接收奖品
# 奖品列表
prize = {'0': 'buwawa',
'1': 'bianxingjingang',
'2': 'aoteman',
'3': 'Python从入门到放弃'
}
# 定义用户字典
login_info = {'nick': '123',
'jishuxiaobai': '123'
}
# 判断登录的次数,最多三次机会
while login_count < 3:
# 与用户交互输入登录名和密码
user = input("请输入登录名:").strip()
pwd = input("请输入密码:").strip()
if login_info.get(user) != pwd:
login_count += 1
print(f"用户名或密码错误,还有{3-login_count}次机会")
continue
login_count = 4
print("登录成功,请开始你的冒险之旅")
# 核心代码,开始猜游戏
while count < 3:
age_str = input("Please enter age:").strip() # 与用户交互输入猜的年龄
# 判断是否是数字
if not age_str.isdigit():
print("请输入数字!!!")
continue
age_int = int(age_str)
# 核心思想,年龄判断是否猜对
if age_int == real_age:
print(f"恭喜,猜对了!!!您可以在以下奖品中选择两件奖品\n{prize}\n")
Y_or_n_prize = input('是否领奖(领奖输入"Y"或者"y"),否则按任意键放弃领奖退出游戏:').strip()
# 放弃领奖
if not (Y_or_n_prize == 'Y' or Y_or_n_prize == 'y'):
print("您已放弃领奖,退出游戏")
break
# 领两件奖品
for i in range(2):
print(f"请选择第{i+1}件奖品,输入对应的数字序号:", end='')
choice = input().strip()
# 判断输入奖品
if choice not in ['0', '1', '2', '3']:
print('看不懂提示吗?输错了')
continue
get_prize.append(prize[choice])
print(f"请领取奖品{get_prize}")
break
elif age_int > real_age:
print("猜大了")
else:
print("猜小了")
count += 1
# 猜错三次后,判断是否继续游戏
if count == 3:
game_again = input('是否继续玩游戏,继续请输入"Y"或者"y",退出游戏请输入"N"或者"n":').strip()
if game_again == 'Y' or game_again == 'y':
count = 0
elif game_again == 'N' or game_again == 'n':
print("你已退出游戏")
break
else:
print("非法输入,请按照要求输入")
day07补充-数据类型总结及拷贝的更多相关文章
- Python 标准类库-数据类型之copy-深拷贝浅拷贝操作
标准类库-数据类型之copy-深拷贝浅拷贝操作 by:授客 QQ:1033553122 Python中赋值并不会拷贝对象,只是创建目标和对象的绑定关系. copy.copy(x) 返回x的浅拷贝 ...
- 基本数据类型补充 set集合 深浅拷贝
一.基本数据类型补充 1,关于int和str在之前的学习中已经介绍了80%以上了,现在再补充一个字符串的基本操作: li = ['李嘉诚','何炅','海峰','刘嘉玲'] s = "_&q ...
- 基础数据类型补充 set集合 深浅拷贝
一.基础数据类型补充 1. "拼接字符串".join(可迭代对象) 可迭代对象为列表时,输出列表元素与拼接字符串的拼接 li = ['张三', '李四', '王五', '赵四'] ...
- 基本数据类型补充,set集合,深浅拷贝等
1.join:将字符串,列表,用指定的字符连接,也可以用空去连接,这样就可以把列表变成str ll = ["wang","jian","wei&quo ...
- 第八天- 基础数据操作补充 集合set 深浅拷贝
字符串的操作补充: .join() 方法用于将序列(字符串/列表/元组/字典)中的 元素 以指定的字符连接生成一个新的字符串 str = "人生苦短我用python!" # 用于字 ...
- 记录我的 python 学习历程-Day07 基础数据类型进阶 / 数据类型之间的转换 / 基础数据类型总结 / 编码的进阶
基础数据类型 str(字符串) str:补充方法练习一遍就行 s.capitalize() 首字母大写,其余变小写 s = 'dyLAn' print(s.capitalize()) # Dylan ...
- day07 python列表 集合 深浅拷贝
day07 python 一.知识点补充 1."".join() s = "".join(('1','2','3','4','5')) #将字符串 ...
- day07(数据类型的相互转换 ,字符编码)
一,复习: ''' 1,深浅拷贝 ls = [1,'a',[10]] 值拷贝:直接赋值 ls1 = ls,ls中的任何值发生改变,ls1也随之发生改变 浅拷贝:通过copy()方法 ls2 = ls. ...
- python之基本数据类型及深浅拷贝
一.数据基本类型之set集合 set和dict类似,也是一组key的集合,但不存储value.由于key不能重复,所以,在set中,没有重复的key set集合,是一个无序且不重复的元素集合 1.创建 ...
随机推荐
- oracle 12c show con_name
今天安装了一个oracle 12c的数据库做测试,在运行一个很简单的命令时出错了: SQL> show con_name concat "." (hex 2e) SP2: u ...
- window+nginx+php-cgi的php-cgi线程/子进程问题
见bbs http://bbs.csdn.net/topics/390803643/close 正常的配置情况下,window的php-cgi是不会出现多线程/子进程的,例如以下配置 fastcgi_ ...
- 从IBM的计划中分析出中国重新相当然的错误选择吗
<IBM欲用物联网技术解决北京雾霾难题> http://security.zol.com.cn/469/4690141.html 读了上文.分析出的. 因为我没有太多的数据.不好分析. 有 ...
- 一款炫酷Loading动画--载入失败
简单介绍 上一篇文章一款炫酷Loading动画–载入成功.给大家介绍了成功动画的绘制过程,这篇文章将接着介绍载入失败特效的制作. 相比成功动画,有了前面的经验,失败动画的过程就显得比較简单了. 动画结 ...
- UVa563_Crimewave(网络流/最大流)(小白书图论专题)
解题报告 思路: 要求抢劫银行的伙伴(想了N多名词来形容,强盗,贼匪,小偷,sad.都认为不合适)不在同一个路口相碰面,能够把点拆成两个点,一个入点.一个出点. 再设计源点s连向银行位置.再矩阵外围套 ...
- SVN合并(merge)的使用
使用svn几年了,一直对分支和合并敬而远之,一来是由于分支的管理不该我担心,二来即使涉及到分支的管理,也不敢贸然使用合并功能,生怕合并出了问题对团队造成不良影响.最基本的原因是,自己对分支的目的和合并 ...
- jeasyui-datagrid使用笔记
formatter转换ID为值 设置字典缓存 var DictionaryItem = {}; $.post('/Dictionary/GetDictionary/T_RKXD', function ...
- BestCoder Round #60/HDU 5505 暴力数学
GT and numbers 问题描述 给出两个数NN和MM. NN每次可以乘上一个自己的因数变成新的NN. 求最初的NN到MM至少需要几步. 如果永远也到不了输出-1−1. 输入描述 第一行读入一个 ...
- Codeforces Round #273 (Div. 2)D. Red-Green Towers DP
D. Red-Green Towers There are r red and g green blocks for construction of the red-green tower. Re ...
- [ZJOI 2009] 假期的宿舍
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1433 [算法] 二分图匹配[代码] #include<bits/stdc++. ...