背景: 最近基于python写接口自动化脚本,从Excel表中读取所有数据,每一行数据保存为字典,then将多行字典数据保存到一个列表中 例子: dd = {"a":1,"b":10} i = 2 list1 = [] while i < 5: dd["a"] = i i +=1 list1.append(dd) print("list1: {}".format(list1)) 预测结果: list1:[{'b': 10, 'a': 2}, {'b': 10, 'a': 3}, {'b': 10, 'a': 4}] 实际结果: list1:[{'b': 10, 'a': 4}, {'b': 10, 'a': 4}, {'b': 10, 'a': 4}] 分析:数据分可变类型和不可变类型,python中字典是可变类型,列表中实际保存的是字典所指的那片内存,而这片内存中内容,保存的是最后一次修改的值。 1 对象的创建和引用 在python中,一切都是对象,对象都具有三个属性:地址_ID,类型_Type,值_Value ID: 一个对象的唯一标识 Type: 标识对象的类型 Value: 对象的值 a is b 通过ID判断 对象a和对象b是否是同一对象 a == b 通过value判断 对象a的值和对象b的值是否相等