数据类型总结

按照存一个值 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补充-数据类型总结及拷贝的更多相关文章

  1. Python 标准类库-数据类型之copy-深拷贝浅拷贝操作

    标准类库-数据类型之copy-深拷贝浅拷贝操作   by:授客 QQ:1033553122 Python中赋值并不会拷贝对象,只是创建目标和对象的绑定关系. copy.copy(x) 返回x的浅拷贝 ...

  2. 基本数据类型补充 set集合 深浅拷贝

    一.基本数据类型补充 1,关于int和str在之前的学习中已经介绍了80%以上了,现在再补充一个字符串的基本操作: li = ['李嘉诚','何炅','海峰','刘嘉玲'] s = "_&q ...

  3. 基础数据类型补充 set集合 深浅拷贝

    一.基础数据类型补充 1. "拼接字符串".join(可迭代对象) 可迭代对象为列表时,输出列表元素与拼接字符串的拼接 li = ['张三', '李四', '王五', '赵四'] ...

  4. 基本数据类型补充,set集合,深浅拷贝等

    1.join:将字符串,列表,用指定的字符连接,也可以用空去连接,这样就可以把列表变成str ll = ["wang","jian","wei&quo ...

  5. 第八天- 基础数据操作补充 集合set 深浅拷贝

    字符串的操作补充: .join() 方法用于将序列(字符串/列表/元组/字典)中的 元素 以指定的字符连接生成一个新的字符串 str = "人生苦短我用python!" # 用于字 ...

  6. 记录我的 python 学习历程-Day07 基础数据类型进阶 / 数据类型之间的转换 / 基础数据类型总结 / 编码的进阶

    基础数据类型 str(字符串) str:补充方法练习一遍就行 s.capitalize() 首字母大写,其余变小写 s = 'dyLAn' print(s.capitalize()) # Dylan ...

  7. day07 python列表 集合 深浅拷贝

    day07 python   一.知识点补充     1."".join() s = "".join(('1','2','3','4','5'))  #将字符串 ...

  8. day07(数据类型的相互转换 ,字符编码)

    一,复习: ''' 1,深浅拷贝 ls = [1,'a',[10]] 值拷贝:直接赋值 ls1 = ls,ls中的任何值发生改变,ls1也随之发生改变 浅拷贝:通过copy()方法 ls2 = ls. ...

  9. python之基本数据类型及深浅拷贝

    一.数据基本类型之set集合 set和dict类似,也是一组key的集合,但不存储value.由于key不能重复,所以,在set中,没有重复的key set集合,是一个无序且不重复的元素集合 1.创建 ...

随机推荐

  1. oracle 12c show con_name

    今天安装了一个oracle 12c的数据库做测试,在运行一个很简单的命令时出错了: SQL> show con_name concat "." (hex 2e) SP2: u ...

  2. window+nginx+php-cgi的php-cgi线程/子进程问题

    见bbs http://bbs.csdn.net/topics/390803643/close 正常的配置情况下,window的php-cgi是不会出现多线程/子进程的,例如以下配置 fastcgi_ ...

  3. 从IBM的计划中分析出中国重新相当然的错误选择吗

    <IBM欲用物联网技术解决北京雾霾难题> http://security.zol.com.cn/469/4690141.html 读了上文.分析出的. 因为我没有太多的数据.不好分析. 有 ...

  4. 一款炫酷Loading动画--载入失败

    简单介绍 上一篇文章一款炫酷Loading动画–载入成功.给大家介绍了成功动画的绘制过程,这篇文章将接着介绍载入失败特效的制作. 相比成功动画,有了前面的经验,失败动画的过程就显得比較简单了. 动画结 ...

  5. UVa563_Crimewave(网络流/最大流)(小白书图论专题)

    解题报告 思路: 要求抢劫银行的伙伴(想了N多名词来形容,强盗,贼匪,小偷,sad.都认为不合适)不在同一个路口相碰面,能够把点拆成两个点,一个入点.一个出点. 再设计源点s连向银行位置.再矩阵外围套 ...

  6. SVN合并(merge)的使用

    使用svn几年了,一直对分支和合并敬而远之,一来是由于分支的管理不该我担心,二来即使涉及到分支的管理,也不敢贸然使用合并功能,生怕合并出了问题对团队造成不良影响.最基本的原因是,自己对分支的目的和合并 ...

  7. jeasyui-datagrid使用笔记

    formatter转换ID为值 设置字典缓存 var DictionaryItem = {}; $.post('/Dictionary/GetDictionary/T_RKXD', function ...

  8. BestCoder Round #60/HDU 5505 暴力数学

    GT and numbers 问题描述 给出两个数NN和MM. NN每次可以乘上一个自己的因数变成新的NN. 求最初的NN到MM至少需要几步. 如果永远也到不了输出-1−1. 输入描述 第一行读入一个 ...

  9. 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 ...

  10. [ZJOI 2009] 假期的宿舍

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1433 [算法] 二分图匹配[代码] #include<bits/stdc++. ...