如何解决蟒蛇|修改未绑定对象仍会同时修改两者
我在复制对象属性时遇到问题,并确保这些属性没有绑定在一起
我在 python 中实现数据表,其属性是 行:列表[列表] column_names : 列表[str]
我想要一种复制表格的方法,例如进行修改,但我希望它完全独立于原始表格,以便采用非破坏性方法
def copy(self):
print(Fore.YELLOW + "COPY FCN BEGINS" + Fore.WHITE)
rows = list(self.rows)
# FOR DEBUG PURPOSES
pprint(rows)
pprint(self.rows)
print(f'{rows is self.rows}')
names = list(self.column_names)
# FOR DEBUG PURPOSES
pprint(names)
pprint(self.column_names)
print(f'{names is self.column_names}')
print(Fore.YELLOW + "COPY FCN ENDS" + Fore.WHITE)
return Tableau( rows= rows,column_names= names )
然后我测试一下 创建一个表并将其复制到另一个 然后我修改新表并确保它只修改了最新的
问题:它同时修改了两者 但是我确保行的列表没有指向同一个对象,所以我有点困惑
结果如下
这里是测试函数(使用 unittest)
测试功能:
def test_copy(self):
# on s'assure que les deux Tableaux sont bien identiques après la copie,mais différents si on en modifie l'un ( ils ne aprtagent pas la même liste en terme d adresse mémoire )
# on copie
NewTable = self.TableauA.copy()
self.assertEqual(NewTable.rows,self.TableauA.rows)
self.assertEqual(NewTable.column_names,self.TableauA.column_names)
print("Row B")
pprint(self.rowB)
print("New Table")
print(NewTable)
print("tableau A")
print(self.TableauA)
print( Fore.GREEN + "IS THE SAME OBJECT ?" + Fore.WHITE)
print(f"{NewTable is self.TableauA}")
print( Fore.GREEN + "ROWS IS THE SAME OBJECT ?" + Fore.WHITE)
print(f"{NewTable.rows is self.TableauA.rows}")
print( Fore.GREEN + "NAMES IS THE SAME OBJECT ?" + Fore.WHITE)
print(f"{NewTable.column_names is self.TableauA.column_names}")
# on modifie le nouveau Tableau
NewTable.add_column(name="NewCol",column=self.rowB)
print(Fore.YELLOW + "MODIFICATION" + Fore.WHITE)
print(Fore.GREEN + "New Table" + Fore.WHITE)
print(NewTable)
print(Fore.GREEN + "tableau A" + Fore.WHITE)
print(self.TableauA)
# on s'assure qu'on a pas modifié les lignes dans les deux
self.assertNotEqual(NewTable.rows,self.TableauA.rows)
return
结果:
最后: add_column 方法
def add_column(self,name : str,column : list,position : int =-1):
n =len(self.rows)
if position == -1 :
position = n
for k in range(n) :
self.rows[k].insert(position,column[k])
self.column_names.insert(position,name)
return
谢谢!
解决方法
找到了,最后很微妙 作为列表列表 层次结构中最高的列表:行确实是独一无二的 然而行的内容 [包含列表的列表] 不是:观察列表仍然绑定甚至使用 list() 函数
这就是我如何让它们独一无二
rows = [ list( self.rows[k] ) for k in range( len(self.rows) ) ]
这是最终有效的代码:
def copy(self):
rows = [ list( self.rows[k] ) for k in range( len(self.rows) ) ]
names = list(self.column_names)
return Tableau( rows= rows,column_names= names )
希望这会帮助其他人
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。