已知列表li = [{"key": 5}, {"key": 9}, {"key": -1}, {"key": 4}] ,
定义一个函数,将该列表按照其元素的value
值进行排序,并输出结果
思路很清晰,新建一个列表,然后遍历取出字典的值加入到新的列表中,再通过遍历,赋值字典,使用append方法依次添加到列表,这样就是一个按照value值排续.于是有了下面的代码:
li = [{"key": 5}, {"key": 9}, {"key": -1}, {"key": 4}]
def fun(li):
li_1 = [] # 接收value值
li_2 = [] # 接收新的字典
dict_1 = {}
for i in range(len(li)):
li_1.append(li[i]["key"])
li_1.sort() # 排序
for i in li_1:
dict_1["key"] = i
print(dict_1)
li_2.append(dict_1)
return li_2
print(fun(li))
但是运行的结果却是:
[{'key': 9}, {'key': 9}, {'key': 9}, {'key': 9}]
很明显,取值被最后一个传入value的9全部替换了.为什么会这样呢?
开始怀疑是不是和字典中重复赋值给"key"有关,但是也不应该啊,每次遍历的时候就是已经把字典append到list中去了啊!
于是使用print(id(dict_1)),查看内存信息,发现这个现象:
2874566784272
2874566784272
2874566784272
2874566784272
居然都是同一地址!!再查看list中的每个元素地址:
for i in li_2:
print(id(i))
结果:(print(id(dict_1))也打印了)
2501747356944
2501747356944
2501747356944
2501747356944
2501747356944
2501747356944
2501747356944
2501747356944
于是明白了,因为每次添加的都是同一个内存到list中去了,dict_1每次写入的时候改变了内存中的value,但是地址不变,即是,创建了一次内存空间,只会不断的改变value了.完善方法:每次遍历时候创建一个新的dict_1.
def fun(li):
li_1 = []
li_2 = []
for i in range(len(li)):
li_1.append(li[i]["key"])
li_1.sort() # 排序
for i in li_1:
dict_1 = {} # 每次遍历时创建一个新的内存
dict_1["key"] = i
li_2.append(dict_1)
return li_2
print(fun(li))
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
您可能感兴趣的文章:
-
-
Python实现正整数分解质因数操作示例
这篇文章主要介绍了Python实现正整数分解质因数操作,结合实例形式分析了Python循环与递归两种操作方法实现分解质因数功能的相关操作技巧,需要的朋友可以参考下
2018-08-08
-
pytest中的fixture基本用法
fixture是pytest特有的功能,用以在测试执行前和执行后进行必要的准备和清理工作,这篇文章主要介绍了pytest中的fixture基本用法,需要的朋友可以参考下
2023-02-02
-
-
Python实现求解括号匹配问题的方法
这篇文章主要介绍了Python实现求解括号匹配问题的方法,涉及Python基于栈的字符串遍历、判断、运算解决括号匹配相关操作技巧,需要的朋友可以参考下
2018-04-04
-
-
-
-
-
-
Python实现快速替换Word文档中的关键字
使用Python自动化处理Word文档可以帮助您提高效率,并减少手动处理文档所需的时间和精力,所以本文为大家准备了Python快速替换Word文档中的关键字的方法,希望对大家有所帮助
2023-06-06