以下是一个示例代码,用于按照id合并数组,并考虑具有重复关联索引的唯一值:
from collections import defaultdict
def merge_arrays(arr1, arr2):
# 使用defaultdict创建一个字典,将每个id作为key,对应的值为一个空列表
merged_dict = defaultdict(list)
# 将arr1中的元素按照id添加到字典中
for item in arr1:
id = item['id']
merged_dict[id].append(item)
# 将arr2中的元素按照id添加到字典中
for item in arr2:
id = item['id']
merged_dict[id].append(item)
# 创建一个空列表,用于存储合并后的结果
merged_array = []
# 遍历字典中的每个key-value对,合并具有相同id的元素
for id, items in merged_dict.items():
merged_item = {}
# 合并具有相同id的元素
for item in items:
merged_item.update(item)
# 将合并后的元素添加到结果列表中
merged_array.append(merged_item)
return merged_array
# 示例输入
arr1 = [{'id': 1, 'name': 'John'}, {'id': 2, 'name': 'Alice'}]
arr2 = [{'id': 1, 'age': 25}, {'id': 3, 'age': 30}]
# 调用函数并输出结果
merged_result = merge_arrays(arr1, arr2)
print(merged_result)
输出结果为:
[{'id': 1, 'name': 'John', 'age': 25}, {'id': 2, 'name': 'Alice'}, {'id': 3, 'age': 30}]
以上代码通过使用defaultdict
创建一个字典,将具有相同id的元素合并为一个字典,并将合并后的结果存储在一个列表中。
上一篇:按照id合并数组并对金额求和
下一篇:按照ID合并行