深浅拷贝:参考:http://www.cnblogs.com/yuanchenqi/articles/5782764.html

s = [[1, 2], 'lily', 'hello']
s2 = s.copy()
print(s2)
s2[0][1] = 3
print(s2)
print(s)
# >>> [[1, 2], 'lily', 'hello']
# >>> [[1, 3], 'lily', 'hello']
# >>> [[1, 3], 'lily', 'hello']
# 输出结果显示当改变列表内的元素的时候,两个会一起改变

s2 = s 和 s2 = s.copy 是不一样的。

s2 = s:是将 s 整体的一个内存地址直接复制给了 s2,相当于 s2 是 s 的一个别名,两个都指向同一块内存空间

s2 = s.copy:是将s 内的每一份地址都拷贝了一份给 s2

浅拷贝:只拷贝一层,不拷贝第二层

深拷贝:克隆一份,和原来完全没关系  s2 = copy.deepcopy(s)


set:

  1. 集合的创建,只有一种方式:s = set(‘lily’) ;每个字符为 1 个单独的元素,重复的只保留一个
  2. 集合对象是一组无序排列的可哈希的值,集合成员可以做字典的键
  3. set 是无序不重复的,没有索引。
  4. 集合分类:可变集合(set) 和 不可变集合(frozenset)

可变集合:可添加和删除元素,非可哈希的,不能用做字典的键,也不能做其他集合的元素

不可变集合:与上面相反

5. 集合操作:

in、not in:判断元素是否在集合中

add():将参数作为一个元素加入集合中

update():将参数作为一个序列,将序列中的每一个内容加入到集合中

remove():删除某个元素

pop():随机删除一个

clear():清空

6. 集合类型操作符

in 、not in

集合等价与不等价(==、!=)   print(set('lilyyyy') == set('liy'))    True

子集,超集   print(set('lilyyyy') < set('lilysu'))    True

a = set([1, 2, 3, 4, 5])

b = set([4, 5, 6, 7, 8])

交集 intersection  print(a.intersection(b)) == print(a & b)

并集 print(a.union(b)) == print(a | b)

差集 print(a.difference(b)) == print(a - b)

反向交集:print(a.symmetric_difference(b)) == print(a ^ b)   反向差集

父集(超集): a.issuperset(b) == print(a > b)

子集:a.issubset(b) == print(a < b)


拷贝相关:

a = b: a、b是不可变数据类型

'''
b = a 语句是直接将 a 指向的内存地址赋值给 b,a、b都指向同一块内存;
当 a 的值改变时,就指向了另一块内存
'''
a = 10
b = a
print(id(a)) #
print(id(b)) #
a = 5
print(id(a)) #
print(id(b)) #

图解:

a = b: a、b是可变数据类型

s = [1, 'lily', ' hello']
s2 = s
print(id(s)) #
print(id(s2)) #
s[0] = 3
print(s) # [3, 'lily', ' hello']
print(s2) # [3, 'lily', ' hello']
print(id(s)) #
print(id(s2)) #

图解:

12 python 初学(深浅拷贝、集合)的更多相关文章

  1. Python原理 -- 深浅拷贝

    python原理 -- 深浅拷贝 从数据类型说开去 str, num : 一次性创建, 不能被修改, 修改即是再创建. list,tuple,dict,set : 链表,当前元素记录, 下一个元素的位 ...

  2. Python的深浅拷贝

    Python的深浅拷贝 深浅拷贝 1. 赋值,对于list, set, dict来说, 直接赋值. 其实是把内存地址交给变量并不是复制一份内容 list1 = [']] list2 = list1 p ...

  3. python 深浅拷贝&集合

    一.深浅拷贝 1.浅拷贝,只会拷贝第一层 s = [1, 'ss', '小可爱'] s1 = s.copy() print(s1) >>> [1, 'ss', '小可爱'] s = ...

  4. python 小数据池 深浅拷贝 集合

    1.小数据池: 1.1代码块: 一个文件,一个函数,一个类,一个模块,终端中每一行 1.1.1 数字: -5 ~ 256 1.1.2 字符串: 乘法时总长度不能超过20 1.1.3 布尔值: 内容相同 ...

  5. 24、简述Python的深浅拷贝以及应用场景

    深浅拷贝的原理 深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:copy.deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝 ...

  6. 简述Python的深浅拷贝以及应用场景

    深浅拷贝的原理 深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:copy.deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝 ...

  7. Python入门-深浅拷贝

    首先我们在这里先补充一下基础数据类型的一些知识: 一.循环删除 1.前面我们学了列表,字典和集合的一些操作方法:增删改查,现在我们来看一下这个问题: 有这样一个列表: lst = ['周杰伦','周润 ...

  8. python 赋值 深浅拷贝

    深浅拷贝 一.数字和字符串 对于 数字 和 字符串 而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 impor ...

  9. python 06 深浅拷贝

    目录 1. 小数据池 1.1 代码块 1.2 小数据池 1.3 执行顺序 (代码块--小数据池) 1.4 "=="和 "is" 2. 深浅拷贝 2.1 赋值 2 ...

随机推荐

  1. layui table 表格模板按钮实例

    这是个是全部的jsp 页面: <%@page pageEncoding="UTF-8" contentType="text/html; charset=UTF-8& ...

  2. 微信小程序调用地图选取位置后返回信息

    先看一下wxml的代码,绑定个事件! <view class='carpool_data_all'> <view class='aa'> <text>*出发地< ...

  3. js获取当前url中参数

    function getUrlParams(url){ var args=new Object(); var query=location.search.substring(1);//获取查询串 va ...

  4. 基于Log4j完成定时创建和删除日志的方法

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 Log4j作为常用的日志生成工具,其清除日志的策略却十分有限. ...

  5. mybatis 通过实体类进行查询

    如果使用实体类进行查询, 不管会不会使用到 主键, 都必须设置主键, 才能查询 <select id="selectByAppidAndServerCode" resultM ...

  6. C# 实现FTP客户端

    本文是利用C# 实现FTP客户端的小例子,主要实现上传,下载,删除等功能,以供学习分享使用. 思路: 通过读取FTP站点的目录信息,列出对应的文件及文件夹. 双击目录,则显示子目录,如果是文件,则点击 ...

  7. springboot部分常用注解

    目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...

  8. c++趣味之变量名,颠覆所有教科书的VisualStudio

    GCC不参与这次的趣味. 所有的教程都会告诉你,c++的变量名,类名,函数名都应该是字母或下划线开头的字母.数字.下划线组合,像这样: int _abc123; 实际上,VisualStudio并不遵 ...

  9. Python——pyHook监听鼠标键盘事件

    pyHook包为Windows中的全局鼠标和键盘事件提供回调. 底层C库报告的信息包括事件的时间,事件发生的窗口名称,事件的值,任何键盘修饰符等. 而正常工作需要pythoncom等操作系统的API的 ...

  10. vue使用axios请求后端数据

    1. 安装axios $ npm install axios 2.在main.js里面导入axios import axios from 'axios' Vue.prototype.$http = a ...