以下是按照id对唯一数组进行排序,保留最后一个值的代码示例:
def sort_array_by_id(arr):
# 创建一个空字典,用于存储每个id对应的最后一个值
id_dict = {}
# 遍历数组中的每个元素
for item in arr:
# 将id作为字典的键,值为当前元素
id_dict[item['id']] = item
# 将字典中的值按照id进行排序
sorted_values = sorted(id_dict.values(), key=lambda x: x['id'])
# 返回排序后的数组
return sorted_values
# 示例用法
array = [
{'id': 2, 'value': 'B'},
{'id': 1, 'value': 'A'},
{'id': 3, 'value': 'C'},
{'id': 2, 'value': 'D'},
{'id': 4, 'value': 'E'},
{'id': 3, 'value': 'F'}
]
sorted_array = sort_array_by_id(array)
print(sorted_array)
输出结果:
[{'id': 1, 'value': 'A'}, {'id': 2, 'value': 'D'}, {'id': 3, 'value': 'F'}, {'id': 4, 'value': 'E'}]
在上述代码中,我们首先创建一个空字典id_dict来存储每个id对应的最后一个值。然后,我们遍历输入数组arr中的元素,并将每个元素的id作为字典id_dict的键,值为当前元素。这样,我们就可以保证字典中每个id对应的值都是最后一个出现的元素。
接下来,我们使用sorted函数对字典id_dict的值进行排序,通过指定key参数为lambda函数,按照元素的id进行排序。最后,我们将排序后的值列表返回。
在示例用法中,输入数组array包含了多个相同id的元素。按照id对数组进行排序后,保留了每个id对应的最后一个元素,即id为1的元素'A',id为2的元素'D',id为3的元素'F',以及id为4的元素'E'。最后,打印排序后的数组sorted_array。
下一篇:按照id对一个组中的计数求和。