我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python学习笔记:第7天 深浅拷贝

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python学习笔记:第7天 深浅拷贝

目录

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

1. 基础数据类型补充

(1)join方法

join方法是把一个列表中的数据进行拼接,拼接成字符串(与split方法相反,split方法是把一个字符串切割成列表)

In [1]: l1 = ['a', 'b', 'c']

In [2]: s1 = ''

In [3]: for i in l1:            # 如果不使用join方法需要自己使用循环拼接成字符串
   ...:     s1 += i + '-'

In [4]: s1.strip('-')
Out[4]: 'a-b-c'

In [5]: l1
Out[5]: ['a', 'b', 'c']

In [6]: s2 = '-'.join(l1)       # 使用join方法可以直接把字符串拼接

In [7]: s2
Out[7]: 'a-b-c'

(2)列表和字典的删除及类型转换

对于列表和字典的删除,有一个需要注意的地方,我们先来看个例子:

In [10]: l2 = [ 'a', 'b', 'c', 'e', 'f' ]

In [11]: for i in l2:
    ...:     l2.remove(i)

In [12]: l2
Out[12]: ['b', 'e']

In [13]:

上面的例子中是遍历列表l2并循环删除列表中的元素,但是最后打印时还存在2个元素‘b’和‘e’,为什么这两个元素没有被删除,分析如下:

  • 首次遍历列表时,i的值为‘a’,然后在列表中把元素删除后,列表中后面的索引位置都往前移动了一位,此时索引为0的位置的值为‘b’
  • 第二次次遍历时,取到索引为1的元素是‘c’,也就是在列表中把‘c’删除了,然后后面的索引又往前移动了
  • 第三次循环时i的值为‘f’,把元素‘f’删除后,循环结束,于是最后还剩下了2个元素

从上面的分析来看,我们可以得出:在循环遍历列表时,不应该去删除列表的元素,否则后续的程序可能出现意料之外的错误;如果需要删除多个元素可以使用下面这种方法:

In [19]: l2 = [ 'a', 'b', 'c', 'e', 'f' ]

In [20]: del_l2 = []

In [21]: for i in l2:           # 遍历列表,把要删除的元素添加到另一个列表中,然后再对列表进行删除
    ...:     del_l2.append(i)

In [22]: for i in del_l2:
    ...:     l2.remove(i)

In [23]: l2
Out[23]: []

In [24]:

然后我们再来看下字典遍历时的问题:

In [24]: d1 = {'a':1, 'b':2}

In [25]: for k in d1:
    ...:     del d1[k]
---------------------------------------------------------------------------
RuntimeError                              Traceback (most recent call last)
<ipython-input-25-a77d5961c011> in <module>
----> 1 for k in d1:
      2     del d1[k]

RuntimeError: dictionary changed size during iteration

In [26]:

从上面的结果可以看出,字典在遍历的时候不允许做删除操作(RuntimeError: dictionary changed size during iteration),要删除时跟列表一样,把要删除的元素的key保存在列表中,循环结束后再删除。

(3)字典的fromkey方法及数据类型转换

fromkey方法

dict中的fromkey(),可以帮我们通过list来创建⼀个dict:

In [26]: dict.fromkeys('abc', 100)
Out[26]: {'a': 100, 'b': 100, 'c': 100}

In [27]: dict.fromkeys('abc', [100, 200, 300])
Out[27]: {'a': [100, 200, 300], 'b': [100, 200, 300], 'c': [100, 200, 300]}

In [28]: d2 = dict.fromkeys('abc', 100)

In [29]: d2
Out[29]: {'a': 100, 'b': 100, 'c': 100}

In [30]: d3 = dict.fromkeys('abc', [100, 200, 300])

In [31]: d3
Out[31]: {'a': [100, 200, 300], 'b': [100, 200, 300], 'c': [100, 200, 300]}

fromkey方法接收两个参数,第一个是一个可迭代的数据,迭代出的每个元素作为字典的key,第二个参数作为字典value,但是这里要注意的是,如果第二个参数是一个可变的数据类型,只要修改其中一个值那么其他的值也会被修改:

In [32]: d3['a'].pop()
Out[32]: 300

In [33]: d3
Out[33]: {'a': [100, 200], 'b': [100, 200], 'c': [100, 200]}

数据类型的转换

  • 元组 => 列表 list(tuple)
  • 列表 => 元组 tuple(list)
  • list=>str str.join(list)
  • str=>list str.split()
  • 转换成False的数据:
    • 0,'',None,[],(),{},set() ==> False
    • 不为空 ===> True

2. set集合

set中的元素是不重复的.⽆序的,⾥⾯的元素必须是可hash的(int, str, tuple,bool), 我们可以这样来记:set就是dict类型的数据但
是不保存value, 只保存key,set也⽤{}表⽰。

set中的元素是不重复的, 且⽆序的:

In [34]: s1 = {'a', 'a', 'b', 'b', 'c'}

In [35]: s1
Out[35]: {'a', 'b', 'c'}

In [36]: s2 = {1, 2, [11, 22]}              # set集合中的元素必须是可hash的,但是set本身是不可hash的
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-36-e5e6f226f8af> in <module>
----> 1 s2 = {1, 2, [11, 22]}

TypeError: unhashable type: 'list'

In [37]:

使用元素唯一性的这个特性,可以对对数据去重处理:

In [39]: l1 = [1, 2, 3, 2, 2, 3]

In [40]: l1
Out[40]: [1, 2, 3, 2, 2, 3]

In [41]: set(l1)
Out[41]: {1, 2, 3}

In [42]:

字典的方法

  • add 添加一个元素
  • clear 清空元素
  • pop 随机删除
  • remove 删除指定元素
  • update 对集合进行更新
  • union 并集运算
  • difference 差集运算
  • intersection 交集运算
  • symmetric_difference 反交集运算
  • issubset 子集
  • issuperset 超集

3. 深浅拷贝

(1)赋值操作

In [44]: a = [1, 2, 3, 4]

In [45]: b = a

In [46]: a.append(10)

In [47]: a, b
Out[47]: ([1, 2, 3, 4, 10], [1, 2, 3, 4, 10])

In [48]: c = {'a':1, 'b':2}

In [49]: d = c

In [50]: d['c'] = 5

In [51]: d
Out[51]: {'a': 1, 'b': 2, 'c': 5}

In [52]: c
Out[52]: {'a': 1, 'b': 2, 'c': 5}

In [53]:

对于list, set, dict来说, 直接赋值. 其实是把内存地址交给变量. 并不是复制⼀份内容. 所以当列表a变了后列表b也跟着变了,字典也是一样。

(2)浅拷贝

In [53]: l1
Out[53]: [1, 2, 3, 2, 2, 3]

In [54]: l2 = l1.copy()

In [55]: l2
Out[55]: [1, 2, 3, 2, 2, 3]

In [56]: l1.append('SEL')

In [57]: print(l1, l2)
[1, 2, 3, 2, 2, 3, 'SEL'] [1, 2, 3, 2, 2, 3]

In [58]:

从上面的例子可以看出,浅复制(使用copy方法)会把列表l1的内容赋值一份给l2,此时修改l1的内容并不会影响列表l2的内容,下面的图可以看出变量存放再内存的情况:

In [61]: l3 = l2.copy()

In [62]: l3
Out[62]: [1, 2, [3, 'SEL']]

In [63]: l2[2].append('hello')

In [64]: l2
Out[64]: [1, 2, [3, 'SEL', 'hello']]

In [65]: l3
Out[65]: [1, 2, [3, 'SEL', 'hello']]

In [66]:

但是此时我们可以看到,使用浅拷贝虽然会复制列表里面的内容,但仅仅是包含第一层,如果列表里面嵌套了列表,内层的列表的内容变话的话,被复制的列表也会变化,如上所示,把l2的值拷贝给l3之后,修改了l2中嵌套的列表,l3中的也会改变,如下图所示:

(3)深拷贝

In [66]: import copy            # 需要导入copy模块

In [67]: l5 = [1, 2, ['a', 'b', ['aa', 'bb'], 3]]

In [68]: l6 = copy.deepcopy(l5)

In [69]: l5
Out[69]: [1, 2, ['a', 'b', ['aa', 'bb'], 3]]

In [70]: l6
Out[70]: [1, 2, ['a', 'b', ['aa', 'bb'], 3]]

In [71]: l5[2][2].append('cc')

In [72]: l5
Out[72]: [1, 2, ['a', 'b', ['aa', 'bb', 'cc'], 3]]

In [73]: l6
Out[73]: [1, 2, ['a', 'b', ['aa', 'bb'], 3]]

In [74]:

深度拷贝会完全复制整个列表里的内容,再次修改之前的列表时,新列表并不会受影响:

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python学习笔记:第7天 深浅拷贝

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python学习笔记:第7天 深浅拷贝

目录 1. 基础数据类型补充 2. set集合 3. 深浅拷贝 1. 基础数据类型补充(1)join方法join方法是把一个列表中的数据进行拼接,拼接成
2023-01-30

Python学习 :深浅拷贝

深浅拷贝 一、浅拷贝只拷贝第一层数据(不可变的数据类型),并创建新的内存空间进行储蓄,例如:字符串、整型、布尔除了字符串以及整型,复杂的数据类型都使用一个共享的内存空间,例如:列表列表使用的是同一个内存地址,指向原拷贝的值,即使用的是原本的
2023-01-30

Python学习笔记:第一天python

目录 1. python简介 2. python的安装 3. 编写第一个helloword 4. 变量和常量 5. 数据类型 6.
2023-01-30

Python学习笔记:第2天while循

目录 1. while循环 continue、break和else语句 2. 格式化输出 3. 运算符 3.1 算数运算
2023-01-30

Python学习教程:Python列表赋值,复制,深拷贝及5种浅拷贝详解

Python学习教程:Python列表赋值,复制,深拷贝及5种浅拷贝详解概述在列表复制这个问题,看似简单的复制却有着许多的学问,尤其是对新手来说,理所当然的事情却并不如意,比如列表的赋值、复制、浅拷贝、深拷贝等绕口的名词到底有什么区别和作用
2023-06-02

python学习笔记:第17天 面向对象

一、类与类之间的依赖关系⼤千世界, 万物之间皆有规则和规律. 我们的类和对象是对⼤千世界中的所有事物进⾏归类. 那事物之间存在着相对应的关系. 类与类之间也同样如此. 在⾯向对象的世界中. 类与类中存在以下关系:依赖关系关联关系组合关系聚合
2023-01-30

python学习笔记:第19天 类的约束

目录 一、类的约束 二、异常处理: 三、MD5加密 四、日志(logging模块) 一、类的约束真正写写项目的代码时都是多人协作的,所以有
2023-01-30

python学习笔记:第16天 面向对象

目录 ⼀、类的成员介绍: 二、类的成员-变量 三、类的成员-方法 四、类的成员-属性 五、私有属性 ⼀、类的成员介绍:⾸先,
2023-01-30

python学习笔记:第6天 小数据池和

目录 1. id 和 == 2. 小数据池 3. 编码和解码 1. id 和 ==id:id是一个内置的函数,可以查看变量存放的内存地址(实际上不是真正
2023-01-30

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录