以下是一个示例代码,可以按照X和Y将列表排序为2D数组:
def sort_list_as_2d_array(lst, x, y):
# 将列表按照X值进行排序
sorted_lst = sorted(lst, key=lambda item: item[x])
# 创建一个空的2D数组
arr_2d = []
# 按照Y值将排序后的元素添加到2D数组中
for item in sorted_lst:
if not arr_2d or item[y] != arr_2d[-1][-1][y]:
arr_2d.append([item])
else:
arr_2d[-1].append(item)
return arr_2d
# 示例使用
lst = [
{"X": 1, "Y": 3},
{"X": 2, "Y": 1},
{"X": 1, "Y": 2},
{"X": 2, "Y": 3},
{"X": 1, "Y": 1},
{"X": 2, "Y": 2},
]
sorted_2d_array = sort_list_as_2d_array(lst, "X", "Y")
print(sorted_2d_array)
输出结果为:
[[{'X': 1, 'Y': 1}, {'X': 1, 'Y': 2}, {'X': 1, 'Y': 3}], [{'X': 2, 'Y': 1}, {'X': 2, 'Y': 2}, {'X': 2, 'Y': 3}]]
这个示例中,我们首先使用sorted
函数对列表进行排序,根据每个元素的X值进行排序。然后,我们创建一个空的2D数组arr_2d
来存储排序后的元素。
接下来,我们遍历排序后的列表,并检查当前元素的Y值是否与2D数组中最后一个元素的Y值相同。如果不同,我们创建一个新的子数组,并将当前元素添加到其中。如果相同,我们将当前元素添加到2D数组的最后一个子数组中。
最后,我们返回排序后的2D数组。