首页 > 编程语言 >Python实战:深拷贝与浅拷贝

Python实战:深拷贝与浅拷贝

时间:2024-03-24 18:58:32浏览次数:26  
标签:实战 Python list1 list2 对象 复制 拷贝 copy

1. 引言

在Python中,对象是通过对内存中的数据进行引用来实现的。当我们创建一个对象并将其赋值给另一个变量时,实际上是将这个对象的引用复制给了另一个变量。这意味着,如果原始对象发生改变,引用该对象的变量也会受到影响。为了解决这个问题,Python提供了深拷贝和浅拷贝两种方式来复制对象。

2. 浅拷贝的原理与实现

浅拷贝(Shallow Copy)是指复制一个对象时,只复制对象本身及其包含的元素,但不复制元素所引用的对象。在Python中,可以使用copy模块的copy()函数来实现浅拷贝。
示例1:浅拷贝列表

import copy
list1 = [1, 2, [3, 4]]
list2 = copy.copy(list1)
list1[0] = 0
list1[2][0] = 0
print(list1)  # 输出:[0, 2, [0, 4]]
print(list2)  # 输出:[1, 2, [0, 4]]

在这个示例中,我们对list1进行了浅拷贝,生成了list2。当修改list1的第一个元素时,list2的第一个元素不受影响。但是,当我们修改list1的第三个元素(一个列表)时,list2的对应元素也发生了改变。这是因为浅拷贝只复制了列表本身,但没有复制列表中的元素所引用的对象。

3. 深拷贝的原理与实现

深拷贝(Deep Copy)是指复制一个对象时,不仅复制对象本身,还复制对象所引用的所有对象。在Python中,可以使用copy模块的deepcopy()函数来实现深拷贝。
示例2:深拷贝列表

import copy
list1 = [1, 2, [3, 4]]
list2 = copy.deepcopy(list1)
list1[0] = 0
list1[2][0] = 0
print(list1)  # 输出:[0, 2, [0, 4]]
print(list2)  # 输出:[1, 2, [3, 4]]

在这个示例中,我们对list1进行了深拷贝,生成了list2。当修改list1的第一个元素时,list2的第一个元素不受影响。同样,当我们修改list1的第三个元素(一个列表)时,list2的对应元素也没有发生改变。这是因为深拷贝复制了列表本身以及列表中的元素所引用的对象。

4. 深拷贝与浅拷贝的应用场景

在实际编程中,深拷贝和浅拷贝的应用场景取决于我们对数据的需求。以下是一些常见的应用场景:
(1)当需要复制一个对象,并且不希望原始对象与复制对象之间存在关联时,可以使用深拷贝。
(2)当需要复制一个对象,并且希望原始对象与复制对象共享一部分数据时,可以使用浅拷贝。
(3)在处理大型数据结构时,深拷贝可能会消耗较多的内存和计算资源。在这种情况下,可以考虑使用浅拷贝。

5. 总结

本文详细介绍了Python中的深拷贝与浅拷贝的原理、实现方法以及在实际编程中的应用。通过具体代码示例,我们了解到深拷贝和浅拷贝的区别以及如何选择合适的复制方式。掌握这两种复制方式对于高效地处理Python中的数据结构至关重要。

标签:实战,Python,list1,list2,对象,复制,拷贝,copy
From: https://blog.csdn.net/oandy0/article/details/136974900

相关文章

  • python + playwright 非无痕模式打开网页下载json数据
    使用python从网页下载资料,生成一些图表使用,因为json数据需要SSO验证,不然没有Token是无权限获取的,所以使用playwright无痕模式打开不行,要使用非无痕模式。从网页报表上把json数据转成Excel保存代码没有多华丽,只是满足了那时候需要這一操作的需求。点击查看代码fromplaywrig......
  • python处理excel,删除行和列+去除重复列
    删除指定的行与列点击查看代码importxlwingsasxw#下載下來的Excel,列和行有很多空白的,要先刪除掉.#打开Excel文件workbook=xw.Book('test.xlsx')sheet=workbook.sheets[0]#删除1-12行sheet.range('1:12').api.EntireRow.Delete()#删除A-G列sheet.range(......
  • Python+openpyxl 拆分Excel合并的单元格
    图片数据是举例子。在实际使用中,从需求网页上下载的生产资料是带有合并单元格的,但在处理的时候需要拆分开,不然不好操作。使用openpyxl可以实现操作如果没有安装openpyxl库,首先安装openpyxl在命令行执行pipinstallopenpyxl点击查看代码importopenpyxlpath=r"test.......
  • python + xlwings 根据条件筛选Excel里的所需资料
    实际有用,有效,满足我的个人需要。点击查看代码importxlwingsasxwdeffiler():try:app=xw.App(visible=False,add_book=False)app2=xw.App(visible=False,add_book=True)wb=app.books.open('new_file.xlsx')#打开原始数据表......
  • Flask项目实战之-注册实现
    注册后端实现 passport/register请求方式:POST传入参数:JSON格式参数参数名类型是否必须参数说明mobilestring是手机号smscodestring是短信验证码passwordstring是密码返回类型:JSON参数名类型是否必须参数说明errnoint是错误码err......
  • BioPython模块的安装
     001、确认是否已经安装(base)[root@pc1~]#pythonPython3.11.4(main,Jul52023,14:15:25)[GCC11.2.0]onlinuxType"help","copyright","credits"or"license"formoreinformation.>>>importBioTraceback......
  • 数学建模 (线性规划 python代码 两种)
    线性规划: 线性规划(LinearProgramming,LP)是一种数学优化方法,用于解决一类特定类型的最优化问题。该问题的目标是在给定的一组线性约束条件下,找到使某个线性目标函数达到最大或最小的变量值。线性规划问题可以表示为以下标准形式:最小化(或最大化):Z=c^T*x约束条件:Ax<=b,......
  • Python编程异步爬虫——aiohttp的使用
    异步爬虫—aiohttp的使用基本介绍asyncio模块其内部实现了对TCP、UDP、SSL协议的异步操作,但是对于HTTP请求来说,就需要用aiohttp实现了。aiohttp是一个基于asyncio的异步HTTP网络模块,它既提供了服务端,又提供了客户端。requests发起的是同步网络请求,aiohttp则是异步。ai......
  • Ubuntu下安装Python虚拟环境
    安装和配置安装包管理神器pipsudoaptinstallpython-pip升级pipsudopipinstall--upgradepip安装virtualenv,virtualenvwrappersudopipinstallvirtualenvsudopipinstallvirtualenvwrapper配置virtualenvwrapper#默认的virtualenvwrapper安装在/u......
  • 机器学习算法那些事 | 使用Transformer模型进行时间序列预测实战
    本文来源公众号“机器学习算法那些事”,仅用于学术分享,侵权删,干货满满。原文链接:使用Transformer模型进行时间序列预测实战时间序列预测是一个经久不衰的主题,受自然语言处理领域的成功启发,transformer模型也在时间序列预测有了很大的发展。本文可以作为学习使用Transformer模......