多维关联数组是很多编程语言中都支持的数据结构,它由多个键值对组成,每个键值对的值又可以是另一个关联数组,形成层级结构。按列拆分指的是提取多维数组中每个子数组的同一个键对应的值,组成一个新的独立一维数组,最终得到多个对应不同键的一维数组。

实现的核心思路
拆分的核心逻辑是先遍历多维数组的每一个子元素,然后针对我们指定的需要拆分的列(也就是键名),把每个子元素中对应键的值收集起来,放到对应键名的结果数组中。整个过程只需要两层循环即可完成,外层循环遍历子数组,内层循环遍历需要提取的键名。
需要处理的前提条件
- 多维数组的每个子数组结构尽量一致,避免出现某个子数组缺少需要提取的键的情况,如果可能出现这种情况,需要提前做键存在性判断
- 明确需要提取的列对应的键名,可以是固定的几个键,也可以动态获取所有子数组的键作为拆分维度
- 结果数组的键可以和原多维数组的子数组键保持一致,方便后续通过键名快速获取对应的一维数组
PHP语言实现示例
PHP的关联数组使用非常广泛,下面给出两种常见的实现方式,第一种是提取指定键的列,第二种是自动提取所有子数组的键进行拆分。
提取指定键的列
<?php
// 原始多维关联数组
$multiArray = [
['id' => 1, 'name' => '张三', 'age' => 20],
['id' => 2, 'name' => '李四', 'age' => 22],
['id' => 3, 'name' => '王五', 'age' => 25],
];
// 需要拆分的列键名
$columns = ['id', 'name', 'age'];
$result = [];
foreach ($multiArray as $item) {
foreach ($columns as $col) {
// 判断子数组是否存在该键,避免报错
if (isset($item[$col])) {
$result[$col][] = $item[$col];
}
}
}
// 打印结果
print_r($result);
?>
上述代码执行后,$result的结构会是['id' => [1,2,3], 'name' => ['张三','李四','王五'], 'age' => [20,22,25]],完成了按列拆分。
动态提取所有键拆分
<?php
$multiArray = [
['id' => 1, 'name' => '张三', 'score' => 90],
['id' => 2, 'name' => '李四', 'score' => 85],
];
$result = [];
foreach ($multiArray as $item) {
foreach ($item as $key => $value) {
$result[$key][] = $value;
}
}
print_r($result);
?>
Python语言实现示例
Python中对应的数据结构是字典组成的列表,实现逻辑和PHP类似,只是语法上有差异。
# 原始多维关联数组(字典列表)
multi_list = [
{'id': 1, 'name': '张三', 'age': 20},
{'id': 2, 'name': '李四', 'age': 22},
{'id': 3, 'name': '王五', 'age': 25},
]
# 指定需要拆分的列
columns = ['id', 'name', 'age']
result = {col: [] for col in columns}
for item in multi_list:
for col in columns:
if col in item:
result[col].append(item[col])
print(result)
注意事项
- 如果多维数组的子数组结构不一致,拆分前最好先统一结构,或者对每个子数组的键做存在性校验,避免出现未定义索引的错误
- 如果原数组的子数组中存在嵌套的关联数组,需要先对嵌套结构做扁平化处理,再按照上述逻辑拆分,否则收集到的值会是整个嵌套数组
- 拆分后的结果数组如果需要保持原数组的顺序,不需要额外处理,因为遍历原数组的顺序是固定的,依次追加到结果数组即可保持顺序
按列拆分多维关联数组是一个很实用的小技巧,掌握后可以大幅简化很多数据处理的逻辑,不需要再手动写多个循环分别提取不同列的数据。