Python--day06(深浅拷贝、元组、字典、集合)
1. 深浅拷贝
1.1 值拷贝
s1直接将ls中存放的地址拿过来
s1内部的值发生任何变化,s2都会随之变化
s1 = ['1','2','3','a']s2 = s1print(id(s1),id(s2)) # 1986703930376 1986703930376s1[2] = 'b'print(id(s1),id(s2)) # 1986703930376 1986703930376
1.2 浅拷贝
s2 = s1.copy()
新开辟列表空间,但列表中的地址都是直接从ls列表中拿来
s1内部的可变类型值发生改变,ls2会随之变化
s1 = ['1','2','3','a',['1','2']]s2 = s1.copy()s1[4][0] = 4print(s1,id(s1)) # ['1', '2', '3', 'a', [4, '2']] 2143274411208print(s2,id(s2)) # ['1', '2', '3', 'a', [4, '2']] 2143275228424

1.3 深拷贝
新开辟列表空间,s1列表中的不可变类型的地址直接拿过来,但是可变类型的地址一定重新开辟空间
from copy import deepcopys1 = ['1','2','3','a',['1','2']]s2 = deepcopy(s1)s1[4][0] = 4print(s1) # ['1', '2', '3', 'a', [4, '2']]print(s2) # ['1', '2', '3', 'a', ['1', '2']]

2. 元组类型
元组:可以理解为不可变的列表
1.值可以为任意类型
2.可以存放多个值 - 可以进行成员运算
3.可以存放重复的值 - 可以计算成员出现的次数
4.有序存储 - 可以通过索引取值,可以切片
2.1 元组的常用操作
2.1.1 索引取值
t = ('1','2','3','a')print(t[0]) # 1
2.1.2 运算(拼接)
t1 = ('1','2','3','a')t2 = (1,2,3)print(t1 + t2) # ('1', '2', '3', 'a', 1, 2, 3)
2.1.3 长度
t1 = ('1','2','3','a')print(len(t1)) # 4
2.1.4 切片
t1 = ('1','2','3','a')print(t1[::-1]) # ('a', '3', '2', '1')
2.1.5 成员运算
t1 = ('1','2','3','a')print('c' in t1) # False
2.1.6 for循环
t1 = ('1','2','3','a')for k in t1: print(k)
3. 字典类型
容器(集合):存放多个值的变量
单列容器(系统中的单列容器很多):list | tuple
双列容器(map):只有dict,存放数据 成对出现,dict存放数据采用 key-value键值对方式
字典中的key可以为什么类型:key必须为不可变类型
-- key是取value的唯一依据,key一旦被确定,就需要唯一确定(不能被改变)
字典中的value可以为什么类型:value可以为任意类型
-- value是用来存放世间所有存在的数据
key要确保唯一性,不能重复,值可以重复,并且可以被改变 => 字典为可变类型
3.1 字典的操作(增删改查)
3.1.1 增
dic = {'a':1,'b':2,'c':3}dic['d'] = 4print(dic) # {'a': 1, 'b': 2, 'c': 3, 'd': 4}
3.1.2 改
dic = {'a':1,'b':2,'c':3}dic['b'] = '4'print(dic) # {'a': 1, 'b': '4', 'c': 3}
3.1.3 查
dic = {'a':1,'b':2,'c':3}print(dic['c']) # 3
3.1.1 删
dic = {'a':1,'b':2,'c':3}print(dic.pop('a')) # 1print(dic) # {'b': 2, 'c': 3}
3.2 字典的其他方法
3.2.1 更新:
dic = {'a':1,'b':2,'c':3}d = {'a':5,'d':10}dic.update(d)print(dic) # {'a': 5, 'b': 2, 'c': 3, 'd': 10}
3.2.2 带默认值的新增: 新增key,key已有,啥事不干,没有添加key,值就是第二个参数
dic = {'a':1,'b':2,'c':3}dic.setdefault('x')print(dic) # {'a': 1, 'b': 2, 'c': 3, 'x': None}dic.setdefault('y',100)print(dic) # {'a': 1, 'b': 2, 'c': 3, 'x': None, 'y': 100}
3.2.3 字典的循环
1.直接循环,就是循环得到keydic = {'a':1,'b':2,'c':3}for k in dic: print(k,end=' ') # a b c
2.循环keys
dic = {'a':1,'b':2,'c':3}for k in dic.keys(): print(k,end=' ') # a b c
3.循环values
dic = {'a':1,'b':2,'c':3}print(dic.values()) # dict_values([1, 2, 3])for k in dic.values(): print(k,end=' ') # 1 2 3
同时循环key和value (key, value)
dic = {'a':1,'b':2,'c':3}print(dic.items()) # dict_items([('a', 1), ('b', 2), ('c', 3)])a, b = (1, 2)print(a, b) # 1 2for res in dic.items(): print(res,end=' ') # ('a', 1) ('b', 2) ('c', 3)
重点:
dic = {'a':1,'b':2,'c':3}for k,v in dic.items(): print(k,v) # a 1 b 2 c 3
4. 集合类型
4.1 概念:
概念:
1.set为可变类型 - 可增可删
2.set为去重存储 - set中不能存放重复数据
3.set为无序存储 - 不能索引取值
4.set为单列容器 - 没有取值的key
总结:set不能取值
4.2 集合的增删
4.2.1 增
s = {'1','2','3','a','b','c'}s.add('d')s.add('1')print(s) # {'b', '3', '2', 'c', 'd', '1', 'a'}
s = {'1','2','3','a','b','c'}s.update({'q','w','e'})print(s) # {'a', '2', 'q', '1', '3', 'c', 'w', 'e', 'b'}
4.2.1 删
s = {'1','2','3','a','b','c'}s.remove('1')print(s) # {'3', '2', 'a', 'b', 'c'}s.clear()print(s) # set()
4.3 集合的运算
交集:两个都有 &
s1 = {'1','2','3','a'}s2 = {'a','b','c','1','2'}print(s1 & s2) # {'a', '1', '2'}print(s1.intersection(s2)) # {'a', '2', '1'}
合集:两个的合体 |
s1 = {'1','2','3','a'} s2 = {'a','b','c','1','2'}print(s1 | s2) # {'1', '2', 'b', 'a', 'c', '3'}print(s1.union(s2)) # {'1', '2', 'b', 'a', 'c', '3'}
对称交集:抛出共有的办法的合体 ^
s1 = {'1','2','3','a'}s2 = {'a','b','c','1','2'}print(s1 ^ s2) # {'c', '3', 'b'}print(s1.symmetric_difference(s2)) # {'c', '3', 'b'}
差集:独有的
s1 = {'1','2','3','a'}s2 = {'a','b','c','1','2'}print(s1 - s2) # {'3'}print(s1.difference(s2)) # {'3'}
比较:前提一定是包含关系
s1 = {'1','2','3','a'}s2 = {'a','b','c','1','2'}s3 = {'1','2'}print(s1 > s2) # Falseprint(s1 > s3) # True
Python--day06(深浅拷贝、元组、字典、集合)的更多相关文章
- python 深浅拷贝 元组 字典 集合操作
深浅拷贝 :值拷贝 :ls = [,,] res = ls 则print(res)就是[,,] 浅拷贝 :ls.copy() 深拷贝:ls3 = deepcopy(ls) # 新开辟列表空间,ls列表 ...
- Python 基础-python-列表-元组-字典-集合
列表格式:name = []name = [name1, name2, name3, name4, name5] #针对列表的操作 name.index("name1")#查询指定 ...
- **python中列表 元组 字典 集合
列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...
- python中列表 元组 字典 集合的区别
列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...
- python3笔记十八:python列表元组字典集合文件操作
一:学习内容 列表元组字典集合文件操作 二:列表元组字典集合文件操作 代码: import pickle #数据持久性模块 #封装的方法def OptionData(data,path): # ...
- python03-break、continue、for循环、数据bytes类型、字符串与字节的关系、变量指向与深浅拷贝、set集合、文件操作
目录: 1.break.continue 2.for循环 3.数据bytes类型 4.字符串与字节的关系 5.变量指向与深浅拷贝 6.set集合 7.文件操作 一.break.continue bre ...
- Python原理 -- 深浅拷贝
python原理 -- 深浅拷贝 从数据类型说开去 str, num : 一次性创建, 不能被修改, 修改即是再创建. list,tuple,dict,set : 链表,当前元素记录, 下一个元素的位 ...
- 元组/字典/集合内置方法+简单哈希表(day07整理)
目录 二十三.元组内置方法 二十四.字典数据类型 二十五 集合内置方法 二十五.数据类型总结 二十六.深浅拷贝 补充:散列表(哈希表) 二十三.元组内置方法 什么是元组:只可取,不可更改的列表 作用: ...
- python_列表——元组——字典——集合
列表——元组——字典——集合: 列表: # 一:基本使用# 1.用途:存放多个值 # 定义方式:[]内以逗号为分隔多个元素,列表内元素无类型限制# l=['a','b','c'] #l=list([' ...
- Python的深浅拷贝
Python的深浅拷贝 深浅拷贝 1. 赋值,对于list, set, dict来说, 直接赋值. 其实是把内存地址交给变量并不是复制一份内容 list1 = [']] list2 = list1 p ...
随机推荐
- Workbooks 对象的 Open 方法参数说明
Workbooks 对象的 Open 方法参数说明 打开一个工作簿. expression.Open(FileName, UpdateLinks, ReadOnly, Format, Password ...
- Adobe系列产品卸载不干净怎么解决
相信很多朋友都遇到过Adobe系列的产品卸载不干净这种问题,究竟如何来解决这个难题呢? Adobe产品在安装的过程中都会自带卸载程序,因此,小编建议各位不要用其他的卸载清理软件来卸载,这样往往会导致卸 ...
- MacBook PyCharm激活码(附视频)
Windows激活请看这里:pyCharm最新2019激活码 此教程实时更新,请放心使用:如果有新版本出现猪哥都会第一时间尝试激活: pycharm官网下载地址:http://www.jetbrain ...
- Windows7下安装pyspark
安装需要如下东西: java jdk-8u181-windows-x64.exe spark spark-2.1.3-bin-hadoop2.7 hadoop(版本要与spark的一致,这里都是had ...
- Java集合详解5:深入理解LinkedHashMap和LRU缓存
今天我们来深入探索一下LinkedHashMap的底层原理,并且使用linkedhashmap来实现LRU缓存. 摘要: HashMap和双向链表合二为一即是LinkedHashMap.所谓Linke ...
- LVS(二)NAT模型配置
NAT配置模式 环境说明 LVS服务器(在eth0:0上设置VIP为:192.168.159.200/24) Eth0:192.168.159.133/24 GW:192.168.159.2 Et ...
- k8s滚动更新(六)--技术流ken
实践 滚动更新是一次只更新一小部分副本,成功后,再更新更多的副本,最终完成所有副本的更新.滚动更新的最大的好处是零停机,整个更新过程始终有副本在运行,从而保证了业务的连续性. 下面我们部署三副本应用, ...
- [JavaScript] requireJS基本使用
requireJS 是一个 AMD 规范的模块加载器主要解决的js开发的4个问题1. 异步加载,防止阻塞页面渲染2. 解决js文件之间的依赖关系和保证js的加载顺序3. 按需加载 来实现一个 requ ...
- Mybatis的基本要素--核心对象
大家好啊,今天呢来说下Mybatis的核心对象,也就是说基本三要素. >核心接口和类. >Mybatis核心配置文件(mybatis-config.xml) >SQL映射文件 一.下 ...
- java爬虫系列第一讲-爬虫入门
1. 概述 java爬虫系列包含哪些内容? java爬虫框架webmgic入门 使用webmgic爬取 http://ady01.com 中的电影资源(动作电影列表页.电影下载地址等信息) 使用web ...