数组 - ThinkPHP数据结构的组织输出问题,求tp大拿帮忙,不胜感激!
黄舟
黄舟 2017-04-10 17:18:13
[PHP讨论组]

小弟纠结这个问题已经一天有余,实在是脑力不够,求tp大拿帮忙,不胜感激!问题如下:
使用tp的过程中,取出如下数据结构,想在模版页面输出,输出的时候需要按照orde_menu_date和orde_dinner_time为第一维,orde_sn为第二维,orde_dish_id和orde_sauce_id为第三维来循环输出,请问如何重新组织数据结构?

数据结构如下:
array (size=6)
0 =>

array (size=9)
  'orde_id' => string '154' (length=3)
  'orde_sn' => string 'aaaa' (length=12)
  'orde_menu_date' => string '2016414' (length=10)
  'orde_dinner_time' => string '0' (length=1)
  'orde_status' => string '0' (length=1)
  'orde_dish_id' => string '12' (length=2)
  'orde_sauc_id' => string '2' (length=1)
  'dish_name' => string '地中海水果沙拉' (length=21)
  'sauc_name' => string '北京甜面酱' (length=15)

1 =>

array (size=9)
  'orde_id' => string '155' (length=3)
  'orde_sn' => string 'bbbbb' (length=32)
  'orde_menu_date' => string '2016414' (length=10)
  'orde_dinner_time' => string '0' (length=1)
  'orde_status' => string '0' (length=1)
  'orde_dish_id' => string '12' (length=2)
  'orde_sauc_id' => string '2' (length=1)
  'dish_name' => string '地中海水果沙拉' (length=21)
  'sauc_name' => string '北京甜面酱' (length=15)

2 =>

array (size=9)
  'orde_id' => string '149' (length=3)
  'orde_sn' => string 'aaaaa' (length=32)
  'orde_menu_date' => string '2016414' (length=10)
  'orde_dinner_time' => string '1' (length=1)
  'orde_status' => string '0' (length=1)
  'orde_dish_id' => string '9' (length=1)
  'orde_sauc_id' => string '0' (length=1)
  'dish_name' => string '红烧肉' (length=9)
  'sauc_name' => null

3 =>

array (size=9)
  'orde_id' => string '151' (length=3)
  'orde_sn' => string 'aaaaa' (length=32)
  'orde_menu_date' => string '2016415' (length=10)
  'orde_dinner_time' => string '0' (length=1)
  'orde_status' => string '0' (length=1)
  'orde_dish_id' => string '1' (length=1)
  'orde_sauc_id' => string '0' (length=1)
  'dish_name' => string '鱼香肉丝' (length=12)
  'sauc_name' => null

4 =>

array (size=9)
  'orde_id' => string '153' (length=3)
  'orde_sn' => string 'aaaaa' (length=32)
  'orde_menu_date' => string '2016415' (length=10)
  'orde_dinner_time' => string '0' (length=1)
  'orde_status' => string '0' (length=1)
  'orde_dish_id' => string '1' (length=1)
  'orde_sauc_id' => string '0' (length=1)
  'dish_name' => string '鱼香肉丝' (length=12)
  'sauc_name' => null

5 =>

array (size=9)
  'orde_id' => string '152' (length=3)
  'orde_sn' => string 'aaaaa' (length=32)
  'orde_menu_date' => string '2016415' (length=10)
  'orde_dinner_time' => string '0' (length=1)
  'orde_status' => string '0' (length=1)
  'orde_dish_id' => string '13' (length=2)
  'orde_sauc_id' => string '0' (length=1)
  'dish_name' => string '羊肉泡馍' (length=12)
  'sauc_name' => null

输出示意如下:

2016-4-14 午餐
单号:aaaaa
地中海水果沙拉(北京甜面酱) x1

单号:bbbbb
地中海水果沙拉(北京甜面酱) x1

2016-4-14 晚餐
单号:aaaaa
红烧肉 x1

2016-4-15 午餐
单号:aaaaa
鱼香肉丝 x2
羊肉泡馍 x1

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回复(2)
PHPz

楼主是想把相同日期且相同产品的订单分成组是吧?这样的话就要循环查询出来的订单,重新构建数组了。


试了一下,不知道是不是你想要的。 (代码有点low 见谅)

$arr = 你的数据;
$data = array();
$a = 0;
$data[$a]['orde_sn'][0] = $arr[0]['orde_sn'];
$data[$a]['orde_menu_date'] = $arr[0]['orde_menu_date'];
$data[$a]['dish_name'][0] = $arr[0]['dish_name'];
$data[$a]['sauc_name'][0] = $arr[0]['sauc_name'];
for($i=1; $i<count($arr); $i++){
    if($arr[$i]['orde_menu_date']==$data[$a]['orde_menu_date']&&$arr[$i]['dish_name']==$data[$a]['dish_name'][0]&&$arr[$i]['sauc_name']==$data[$a]['sauc_name'][0]){
        $data[$a]['orde_sn'][$i] = $arr[$i]['orde_sn'];
        $data[$a]['dish_name'][$i] = $arr[$i]['dish_name'];
        $data[$a]['sauc_name'][$i] = $arr[$i]['sauc_name'];
    }else{
        $a = $a+1;
        $data[$a]['orde_sn'][0] = $arr[$i]['orde_sn'];
        $data[$a]['orde_menu_date'] = $arr[$i]['orde_menu_date'];
        $data[$a]['dish_name'][0] = $arr[$i]['dish_name'];
        $data[$a]['sauc_name'][0] = $arr[$i]['sauc_name'];
    }
}
高洛峰

分组......

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号