php - 将一维数组转换为多维数组

标签 php mysql arrays

您好,我有以下数组列表,我需要将其转换为按公司分组并将类别显示为第二个数组的内容。

 [0] => Array
  (
    [company_id] => 1
    [avatar] => '092EF7DB-B478-2EF5-1CC5-4A46D285B5F0.jpg'
    [comp_name] => Hotel 1
    [categories] => Array
    (
      [cat_+category_id] => Reception
      [cat_+category_id] => Accommodation
    )

[1] => Array
      (
        [company_id] => 8
        [avatar] => ''
        [comp_name] => Hotel 2
        [categories] => Array
        (
          [cat_+category_id] => Reception

        )
etc 

原始数组如下

0 => {#359 ▼
  +"category_id": 10
  +"company_id": 1
  +"cat": "Reception"
  +"comp_name": "Hotel 1"
  +"avatar": "092EF7DB-B478-2EF5-1CC5-4A46D285B5F0.jpg"
}
1 => {#354 ▼
  +"category_id": 12
  +"company_id": 1
  +"cat": "Accomodation"
  +"comp_name": "Hotel 1"
  +"avatar": "092EF7DB-B478-2EF5-1CC5-4A46D285B5F0.jpg"
}
2 => {#358 ▼
  +"category_id": 10
  +"company_id": 8
  +"cat": "Reception"
  +"comp_name": "Hotel 2"
  +"avatar": null
}
3 => {#361 ▼
  +"category_id": 10
  +"company_id": 23
  +"cat": "Reception"
  +"comp_name": "Hotel 3"
  +"avatar": null
}
4 => {#365 ▼
  +"category_id": 12
  +"company_id": 23
  +"cat": "Accomodation"
  +"comp_name": "Hotel 3"
  +"avatar": null

请问如何在php中实现它 谢谢 丹妮

最佳答案

假设$originalArr是你原来的一维数组,将一维数组转换为多维数组的解决方案如下:

$resultArr = array();
foreach($originalArr as $arr){
    if(!isset($resultArr[$arr['company_id']])){
        $resultArr[$arr['company_id']] = array('company_id' => $arr['company_id'], 
                                            'avatar' => $arr['avatar'],
                                            'comp_name' => $arr['comp_name'],
                                            'categories' => array('cat_' . $arr['category_id'] => $arr['cat'])
                                        );
    }else{
        $resultArr[$arr['company_id']]['categories']['cat_' . $arr['category_id']] = $arr['cat'];
    }
}
$resultArr = array_values($resultArr);

// display $resultArr array
var_dump($resultArr);

关于php - 将一维数组转换为多维数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43695867/

相关文章:

php mysql_num_rows() 函数不起作用

javascript - Node js :add mysql query result to json in forloop

php - 将 blob 图像检索到 html php

mysql - 如何在 MySQL 上不使用 HAVING 进行 COUNT 或类似操作?

java - Android/Java 中奇怪的字符串数组行为

c++ - 哪种数据结构支持高效删除和随机访问?

php - 如果 MySQL 数据库没有关闭会发生什么?

php - Mysqli查询函数插入重复行

java - java中的两个数组打乱顺序

php - 使用 array_intersect 将数组与重复值进行比较?