python_copy

部署运行你感兴趣的模型镜像

浅copy

data = {
    "name":"chaoyang",
    "age":"28",
    "scores":{
         "语文":130,
        "数学":60,
        "英语":98,
    }
}

d = data
data["age"] = 20
print(d)
{'name': 'chaoyang', 'age': 20, 'scores': {'语文': 130, '数学': 60, '英语': 98}}

为何是20呢,因为d=data相当于只是拿到了data的内存地址,但data里的每个k,v都是有单独的内存的地址的。d,data会一直共享这个dict里的数据,不会出现像之前字符串a=1,b=a, a=2, b依然等于1的情况。

复制一份dict数据

>>> data
{'name': 'chaoyang', 'age': 20, 'scores': {'语文': 130, '数学': 60, '英语': 98}}
>>> d1 = data.copy()
>>> data["age"] = 22
>>> print(d1)
{'name': 'chaoyang', 'age': 20, 'scores': {'语文': 130, '数学': 60, '英语': 98}}
>>> print(data)
{'name': 'chaoyang', 'age': 22, 'scores': {'语文': 130, '数学': 60, '英语': 98}}

相当于有2份独立的数据了,但是修改scores的值

>>> data
{'name': 'chaoyang', 'age': 22, 'scores': {'语文': 130, '数学': 60, '英语': 98}}
>>> d2 = data.copy()
>>> data["age"] = 20
>>> data["scores"]["数学"] = 120
>>> data
{'name': 'chaoyang', 'age': 20, 'scores': {'语文': 130, '数学': 120, '英语': 98}}
>>> d2
{'name': 'chaoyang', 'age': 22, 'scores': {'语文': 130, '数学': 120, '英语': 98}}

两个dict的值是独立的,但score字典里的数据是共享的,故scores下的数据是共享一份的

深copy

复制两份完全独立的数据

>>> import copy
>>> data
{'name': 'chaoyang', 'age': 20, 'scores': {'语文': 130, '数学': 120, '英语': 98}}
>>> d2 = data.copy()
>>> d3 = copy.deepcopy(data)
>>> d3["scores"]["语文"] = 140
>>> print(data)
{'name': 'chaoyang', 'age': 20, 'scores': {'语文': 130, '数学': 120, '英语': 98}}
>>> print(d3)
{'name': 'chaoyang', 'age': 20, 'scores': {'语文': 140, '数学': 120, '英语': 98}}

 

您可能感兴趣的与本文相关的镜像

Python3.10

Python3.10

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

### Python `__copy__` 方法的用法 在 Python 中,对象可以通过浅拷贝(shallow copy)或深拷贝(deep copy)来进行复制。对于自定义类的对象,默认情况下只支持浅拷贝操作。为了实现更复杂的复制行为,可以重载 `__copy__` 和 `__deepcopy__` 特殊方法。 #### 浅拷贝与深拷贝的区别 当执行浅拷贝时,创建的新对象会包含原始对象中所有子对象的引用而不是副本。而深拷贝则不仅复制顶层对象本身,还会递归地复制其内部所有的嵌套对象[^1]。 #### 使用 `copy.copy()` 进行浅拷贝 要调用某个对象的 `__copy__` 方法,通常不会直接访问该特殊名称的方法,而是借助于标准库中的 `copy` 模块所提供的接口函数: ```python import copy class MyClass: def __init__(self, name, items=None): self.name = name if items is None: items = [] self.items = items def add_item(self, item): self.items.append(item) original = MyClass('Original', ['item1']) copied = copy.copy(original) # 调用了MyClass.__copy__() 或者默认实现了浅拷贝逻辑 ``` 在这个例子中,如果没有特别定义 `__copy__` 方法,则上述代码将触发默认的行为——即仅复制顶级属性而不影响列表内的元素指向相同的内存地址。 #### 自定义 `__copy__` 行为 如果希望改变这种默认行为,可以在自己的类里显式提供一个 `__copy__` 实现: ```python from copy import copy class CustomCopyable: def __init__(self, data): self.data = data def __copy__(self): cls = self.__class__ result = cls.__new__(cls) result.__dict__.update(self.__dict__) return result obj = CustomCopyable([1, 2, 3]) clone = copy(obj) print(clone is obj) # False print(clone.data is obj.data)# True (因为这是个浅拷贝的例子) ``` 这里展示了如何覆盖 `__copy__` 来控制实例被复制后的状态初始化过程。需要注意的是,在这个简单的案例下,我们仍然得到的是原数据结构的一个新视图而非完全独立的数据集,这是因为这依然是基于浅拷贝机制的工作方式。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值