phpexecl导出 循环时间问题
伊谢尔伦
伊谢尔伦 2017-04-10 14:34:47
0
2
530

做php导出,需要循环输出数据到execl中,一开始写了一个,觉得时间有点长,就缩短了下,发现时间还变多了,求教这是为什么啊?谢谢了先。

原先的代码片段:

//归总每个一级分类下的二级分类
foreach($first_cate_array as $fkey => $fvalue){
    foreach($cate as $ck=>$cv){                             
        if($cv['parentid'] == $fvalue['id']){
            $first_cate_array[$fkey]['second_cate'][] = $cv;
        }
    }

    //获得每个一级分类下二级分类的数目
    $second_count = count($first_cate_array[$fkey]['second_cate']); 
    $first_cate_array[$fkey]['second_count'] = $second_count == 0 ? 1 : $second_count;  
}

/*************************************************************************/
foreach($first_cate_array as $fk => $fv){
    //一级目录起始行数
    if($fk == 0){
        $stapos = $num;
        $en_stapos = $stapos+$cate_count;
    }else{
        $stapos = $stapos+$first_cate_array[$fk-1]['second_count'];
        $en_stapos = $stapos+$cate_count;
    }

    foreach($fv['second_cate'] as $sck => $scv){
        //二级目录起始行数
        $stapos1 = $stapos+$sck;
        $en_stapos1 = $en_stapos+$sck;
        foreach($scv['pro'] as $spk => $spv){
            $str1 = 70+$spk*3;
            $str1 = chr($str1);
            $str2 = 71+$spk*3;
            $str2 = chr($str2);
            $str3 = 72+$spk*3;
            $str3 = chr($str3);
            //中文
            $collect = $spv['name'].'('.$spv['description'].')';
            $objActSheet->setCellValue($str1.$stapos1, $collect);
            $objActSheet->setCellValue($str2.$stapos1, $spv['name']);
            $objActSheet->setCellValue($str3.$stapos1, $spv['description']);
            //英文
            $en_collect = $spv['en_name'].'('.$spv['en_description'].')';
            $objActSheet->setCellValue($str1.$en_stapos1, $en_collect);
            $objActSheet->setCellValue($str2.$en_stapos1, $spv['en_name']);
            $objActSheet->setCellValue($str3.$en_stapos1, $spv['en_description']);
        }
        //中文
        $objActSheet->setCellValue('E'.$stapos1, $scv['category']);
        //英文
        $objActSheet->setCellValue('E'.$en_stapos1, $scv['en_category']);
    }
    //中文
    $objActSheet->setCellValue('D'.$stapos, $fv['category']);
    $stopos = $stapos + $fv['second_count'] - 1;
    $mergecellstr = 'D'.$stapos.':D'.$stopos;
    $objActSheet->mergeCells($mergecellstr);
    //英文
    $objActSheet->setCellValue('D'.$en_stapos, $fv['en_category']);
    $en_stopos = $en_stapos + $fv['second_count'] - 1;
    $en_mergecellstr = 'D'.$en_stapos.':D'.$en_stopos;
    $objActSheet->mergeCells($en_mergecellstr);
}

修改以后的片段:

$second_count = 0;
//归总每个一级分类下的二级分类
foreach($first_cate_array as $fkey => $fvalue){
    //一级目录起始行数
    $stapos = $num+$second_count;
    $en_stapos = $stapos+$cate_count;
    $second_stapos = 0;
    foreach($cate as $ck=>$cv){
        if($cv['parentid'] == $fvalue['id']){
            //二级目录起始行数
            $stapos1 = $stapos+$second_stapos;
            $en_stapos1 = $en_stapos+$second_stapos;                                    
            foreach($cv['pro'] as $spk => $spv){
                $str1 = 70+$spk*3;
                $str1 = chr($str1);
                $str2 = 71+$spk*3;
                $str2 = chr($str2);
                $str3 = 72+$spk*3;
                $str3 = chr($str3);
                //中文
                $collect = $spv['name'].'('.$spv['description'].')';
                $objActSheet->setCellValue($str1.$stapos1, $collect);
                $objActSheet->setCellValue($str2.$stapos1, $spv['name']);
                $objActSheet->setCellValue($str3.$stapos1, $spv['description']);
                //英文
                $en_collect = $spv['en_name'].'('.$spv['en_description'].')';
                $objActSheet->setCellValue($str1.$en_stapos1, $en_collect);
                $objActSheet->setCellValue($str2.$en_stapos1, $spv['en_name']);
                $objActSheet->setCellValue($str3.$en_stapos1, $spv['en_description']);
            }
            //中文
            $objActSheet->setCellValue('E'.$stapos1, $cv['category']);
            //英文
            $objActSheet->setCellValue('E'.$en_stapos1, $cv['en_category']);
            $second_stapos ++ ;
            $second_count ++ ;
        }
    }                           
    //中文
    $objActSheet->setCellValue('D'.$stapos, $fvalue['category']);
    $stopos = $num + $second_count - 1;
    $mergecellstr = 'D'.$stapos.':D'.$stopos;
    $objActSheet->mergeCells($mergecellstr);
    //英文
    $objActSheet->setCellValue('D'.$en_stapos, $fvalue['en_category']);
    $en_stopos = $num + $cate_count + $second_count - 1;
    $en_mergecellstr = 'D'.$en_stapos.':D'.$en_stopos;
    $objActSheet->mergeCells($en_mergecellstr);
}

我觉得原先的代码多一个上面的循环,时间应该多一点。。。查询1700条数据耗时84s。。。 下面附上全文代码:

    /**
     * 导出Execl
     */
    public function export(){
        import("@.ORG.PhpExcel");
        //import("Lib.ORG.PHPExcel.IOFactory",APP_PATH,".php");
        import("Lib.ORG.PHPExcel.Writer.Excel5",APP_PATH,".php");
        import("Lib.ORG.PHPExcel.Writer.Excel2007",APP_PATH,".php");

        // 创建一个处理对象实例   
        $objPHPExcel = new PHPExcel();   

        // 创建文件格式写入对象实例, uncomment   
        //$objWriter = new PHPExcel_Writer_Excel5($objPHPExcel);                // 用于其他版本格式   
        // or   
        $objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel);               // 用于 2007 格式   
        //$objWriter->setOffice2003Compatibility(true);   

        //*************************************   
        //设置文档基本属性   
//      $objProps = $objPHPExcel->getProperties();   
//      $objProps->setCreator("Test");                                          //创建人
//      $objProps->setLastModifiedBy("Test");                                   //最后修改人
//      $objProps->setTitle("Office XLS Test Document");                        //标题
//      $objProps->setSubject("Office XLS Test Document, Demo");                //题目
//      $objProps->setDescription("Test document, generated by PHPExcel.");     //描述
//      $objProps->setKeywords("office excel PHPExcel");                        //关键字
//      $objProps->setCategory("Test");                                         //种类

        //*************************************   
        //设置当前的sheet索引,用于后续的内容操作。   
        //一般只有在使用多个sheet的时候才需要显示调用。   
        //缺省情况下,PHPExcel会自动创建第一个sheet被设置SheetIndex=0   
        $objPHPExcel->setActiveSheetIndex(0);   

        $objActSheet = $objPHPExcel->getActiveSheet();   

        //设置当前活动sheet的名称   
        //$objActSheet->setTitle('测试Sheet');

        //*************************************  
        //设置单元格内容   
        //   
        //由PHPExcel根据传入内容自动判断单元格内容类型   
        //$objActSheet->setCellValue('A1', '字符串内容');                        // 字符串内容   
        //$objActSheet->setCellValue('A2', 26);                                 // 数值   
        //$objActSheet->setCellValue('A3', true);                               // 布尔值   
        //$objActSheet->setCellValue('A4', '=SUM(A2:A2)');                      // 公式     

        //填入主标题
        $objActSheet->setCellValue('A1', '电子地图');
        $objActSheet->mergeCells('A1:AC1');
        //设置表头行高
        $objActSheet->getRowDimension(1)->setRowHeight(20);

        $objActSheet->setCellValue('A2', '序号');
        $objActSheet->mergeCells('A2:A4');   
        $objActSheet->setCellValue('B2', '公司名称');
        $objActSheet->mergeCells('B2:B4');  
        $objActSheet->setCellValue('C2', '简称');
        $objActSheet->mergeCells('C2:C4'); 
        $objActSheet->setCellValue('D2', '产品与技术');
        $objActSheet->mergeCells('D2:N2'); 
        $objActSheet->setCellValue('O2', '相关信息');
        $objActSheet->mergeCells('O2:S2');
        $objActSheet->setCellValue('T2', '联系信息');
        $objActSheet->mergeCells('T2:AB2');
        $objActSheet->setCellValue('AC2', '描述');
        $objActSheet->mergeCells('AC2:AC4');

        $objActSheet->setCellValue('D3', '领域');
        $objActSheet->mergeCells('D3:E3');
        $objActSheet->setCellValue('F3', '产品');
        $objActSheet->mergeCells('F3:N3');
        $objActSheet->setCellValue('O3', '技术');
        $objActSheet->mergeCells('O3:O4');
        $objActSheet->setCellValue('P3', '应用');
        $objActSheet->mergeCells('P3:P4');
        $objActSheet->setCellValue('Q3', '性质');
        $objActSheet->mergeCells('Q3:Q4');
        $objActSheet->setCellValue('R3', '成立时间');
        $objActSheet->mergeCells('R3:R4');
        $objActSheet->setCellValue('S3', '员工数');
        $objActSheet->mergeCells('S3:S4');
        $objActSheet->setCellValue('T3', '地址');
        $objActSheet->mergeCells('T3:T4');
        $objActSheet->setCellValue('U3', '电话');
        $objActSheet->mergeCells('U3:U4');
        $objActSheet->setCellValue('V3', '传真');
        $objActSheet->mergeCells('V3:V4');
        $objActSheet->setCellValue('W3', 'eMail');
        $objActSheet->mergeCells('W3:W4');
        $objActSheet->setCellValue('X3', '网站');
        $objActSheet->mergeCells('X3:X4');
        $objActSheet->setCellValue('Y3', '经度');
        $objActSheet->mergeCells('Y3:Y4');
        $objActSheet->setCellValue('Z3', '纬度');
        $objActSheet->mergeCells('Z3:Z4');
        $objActSheet->setCellValue('AA3', '园区');
        $objActSheet->mergeCells('AA3:AA4');
        $objActSheet->setCellValue('AB3', '城市');
        $objActSheet->mergeCells('AB3:AB4');

        $objActSheet->setCellValue('D4', '一级');
        $objActSheet->setCellValue('E4', '二级');
        $objActSheet->setCellValue('F4', '1');
        $objActSheet->setCellValue('G4', '品名');
        $objActSheet->setCellValue('H4', '描述');
        $objActSheet->setCellValue('I4', '2');
        $objActSheet->setCellValue('J4', '品名');
        $objActSheet->setCellValue('K4', '描述');
        $objActSheet->setCellValue('L4', '3');
        $objActSheet->setCellValue('M4', '品名');     
        $objActSheet->setCellValue('N4', '描述');

        //*************************************   
        //搜索条件
        $company_where = 1;
        $keyword = trim($_GET['keyword']);
        if($_GET['sub_category'] || $_GET['first_cid']){
            $c_uid =getuidbycate();
        }
        if($_GET['product_id']){
            $p_uid =getuidbypro($_GET['product_id']);
        }
        $uid_arr = $p_uid?array_intersect($c_uid,$p_uid):$c_uid;
        $uid_str = implode(',',$uid_arr);
        if($_GET['sub_category'] || $_GET['first_cid'] || $_GET['product_id']){
            $company_where .= ' and uid in('.$uid_str.')';
        }
        if($keyword){
            $company_where .= " and company like '%$keyword%'";
        }

        $num = 5;       //初始行数

        //公司信息  
        $company = $this->Company->field('')->where($company_where)->select();
        if($company){
            foreach((array)$company as $k => $v){
                if($v['uid']){
                    //获取产品
                    $pro = $this->Product->table(tname('product').' AS pr')->join(tname('company_product').' AS cp ON pr.id=cp.pid')->field('')->where('cp.uid='.$v['uid'])->group('pr.id')->select();
                    $company[$k]['pid'] = $pro;
                    //获取二级分类
                    $join = tname('company_category').' AS cc ON ca.id=cc.cid';
                    $field = ''; 
                    $where = "cc.uid=".$v['uid'];
                    $cate = $this->Category->table(tname('category').' AS ca')->join($join)->field($field)->where($where)->group('ca.id')->select();
                    if($cate){
                        $cate_count = count($cate);
                        $second_cate = '';
                        $first_cate_array = '';
                        foreach($cate as $k1=>$v1){
                            //获取一级分类
                            $first_cate = $this->Category->where('id='.$v1['parentid'])->find();
                            //归总公司的一级分类
                            if(!in_array($first_cate,$first_cate_array)){
                                $first_cate_array[] = $first_cate;
                            }
                            //归类二级分类下的产品
                            foreach($pro as $pk => $pv){
                                if($pv['cid'] == $v1['cid']){
                                    $cate[$k1]['pro'][] = $pv;
                                }
                            }
                        }

                        /**************************************************************************/
//                      $second_count = 0;
//                      //归总每个一级分类下的二级分类
//                      foreach($first_cate_array as $fkey => $fvalue){
//                          //一级目录起始行数
//                          $stapos = $num+$second_count;
//                          $en_stapos = $stapos+$cate_count;
//                          $second_stapos = 0;
//                          foreach($cate as $ck=>$cv){
//                              if($cv['parentid'] == $fvalue['id']){
//                                  //二级目录起始行数
//                                  $stapos1 = $stapos+$second_stapos;
//                                  $en_stapos1 = $en_stapos+$second_stapos;                                    
//                                  foreach($cv['pro'] as $spk => $spv){
//                                      $str1 = 70+$spk*3;
//                                      $str1 = chr($str1);
//                                      $str2 = 71+$spk*3;
//                                      $str2 = chr($str2);
//                                      $str3 = 72+$spk*3;
//                                      $str3 = chr($str3);
//                                      //中文
//                                      $collect = $spv['name'].'('.$spv['description'].')';
//                                      $objActSheet->setCellValue($str1.$stapos1, $collect);
//                                      $objActSheet->setCellValue($str2.$stapos1, $spv['name']);
//                                      $objActSheet->setCellValue($str3.$stapos1, $spv['description']);
//                                      //英文
//                                      $en_collect = $spv['en_name'].'('.$spv['en_description'].')';
//                                      $objActSheet->setCellValue($str1.$en_stapos1, $en_collect);
//                                      $objActSheet->setCellValue($str2.$en_stapos1, $spv['en_name']);
//                                      $objActSheet->setCellValue($str3.$en_stapos1, $spv['en_description']);
//                                  }
//                                  //中文
//                                  $objActSheet->setCellValue('E'.$stapos1, $cv['category']);
//                                  //英文
//                                  $objActSheet->setCellValue('E'.$en_stapos1, $cv['en_category']);
//                                  $second_stapos ++ ;
//                                  $second_count ++ ;
//                              }
//                          }                           
//                          //中文
//                          $objActSheet->setCellValue('D'.$stapos, $fvalue['category']);
//                          $stopos = $num + $second_count - 1;
//                          $mergecellstr = 'D'.$stapos.':D'.$stopos;
//                          $objActSheet->mergeCells($mergecellstr);
//                          //英文
//                          $objActSheet->setCellValue('D'.$en_stapos, $fvalue['en_category']);
//                          $en_stopos = $num + $cate_count + $second_count - 1;
//                          $en_mergecellstr = 'D'.$en_stapos.':D'.$en_stopos;
//                          $objActSheet->mergeCells($en_mergecellstr);
//                      }

                        /**************************************************************************/

                        //归总每个一级分类下的二级分类
                        foreach($first_cate_array as $fkey => $fvalue){
                            foreach($cate as $ck=>$cv){                             
                                if($cv['parentid'] == $fvalue['id']){
                                    $first_cate_array[$fkey]['second_cate'][] = $cv;
                                }
                            }

                            //获得每个一级分类下二级分类的数目
                            $second_count = count($first_cate_array[$fkey]['second_cate']); 
                            $first_cate_array[$fkey]['second_count'] = $second_count == 0 ? 1 : $second_count;  
                        }

                        /*************************************************************************/
                        foreach($first_cate_array as $fk => $fv){
                            //一级目录起始行数
                            if($fk == 0){
                                $stapos = $num;
                                $en_stapos = $stapos+$cate_count;
                            }else{
                                $stapos = $stapos+$first_cate_array[$fk-1]['second_count'];
                                $en_stapos = $stapos+$cate_count;
                            }

                            foreach($fv['second_cate'] as $sck => $scv){
                                //二级目录起始行数
                                $stapos1 = $stapos+$sck;
                                $en_stapos1 = $en_stapos+$sck;
                                foreach($scv['pro'] as $spk => $spv){
                                    $str1 = 70+$spk*3;
                                    $str1 = chr($str1);
                                    $str2 = 71+$spk*3;
                                    $str2 = chr($str2);
                                    $str3 = 72+$spk*3;
                                    $str3 = chr($str3);
                                    //中文
                                    $collect = $spv['name'].'('.$spv['description'].')';
                                    $objActSheet->setCellValue($str1.$stapos1, $collect);
                                    $objActSheet->setCellValue($str2.$stapos1, $spv['name']);
                                    $objActSheet->setCellValue($str3.$stapos1, $spv['description']);
                                    //英文
                                    $en_collect = $spv['en_name'].'('.$spv['en_description'].')';
                                    $objActSheet->setCellValue($str1.$en_stapos1, $en_collect);
                                    $objActSheet->setCellValue($str2.$en_stapos1, $spv['en_name']);
                                    $objActSheet->setCellValue($str3.$en_stapos1, $spv['en_description']);
                                }
                                //中文
                                $objActSheet->setCellValue('E'.$stapos1, $scv['category']);
                                //英文
                                $objActSheet->setCellValue('E'.$en_stapos1, $scv['en_category']);
                            }
                            //中文
                            $objActSheet->setCellValue('D'.$stapos, $fv['category']);
                            $stopos = $stapos + $fv['second_count'] - 1;
                            $mergecellstr = 'D'.$stapos.':D'.$stopos;
                            $objActSheet->mergeCells($mergecellstr);
                            //英文
                            $objActSheet->setCellValue('D'.$en_stapos, $fv['en_category']);
                            $en_stopos = $en_stapos + $fv['second_count'] - 1;
                            $en_mergecellstr = 'D'.$en_stapos.':D'.$en_stopos;
                            $objActSheet->mergeCells($en_mergecellstr);
                        }
                        $company[$k]['first_cid'] = $first_cate_array;
                    }
                    //$company[$k]['first_count'] = count($company[$k]['first_cid']);
                    //获得二级分类的总数目
                    $company[$k]['total_rows'] = count($cate);

                    //园区
                    if($v['park']){
                        $park = my_explode($v['park']);
                        $company[$k]['park'] = my_arrytostr(array_unique($park),'Park','name');
                        $company[$k]['en_park'] = my_arrytostr(array_unique($park),'Park','en_name');
                    }else{
                        $v['park'] = '';
                        $v['en_park'] = '';
                    }
                    //城市
                    if($v['city']){
                        $city = C('CITY');
                        foreach($city as $ck=>$cv){
                            if($v['city'] == $cv['id']){
                                $v['city'] = $cv['name'];
                                $v['en_city'] = $cv['en_name'];
                            }
                        }
                    }

                    $total_rows = $company[$k]['total_rows'] == 0 ? 1 : $company[$k]['total_rows'];
                    //中文*************************************   
                    $stop = $num - 1 + $total_rows;

                    $objActSheet->setCellValue('A'.$num, $v['uid']);
                    $objActSheet->mergeCells('A'.$num.':A'.$stop);
                    $objActSheet->setCellValue('B'.$num, $v['company']);
                    $objActSheet->mergeCells('B'.$num.':B'.$stop);
                    $objActSheet->setCellValue('C'.$num, $v['com']);
                    $objActSheet->mergeCells('C'.$num.':C'.$stop);
//
//                  $objActSheet->setCellValue('D'.$num, $v['com']);
//                  $objActSheet->setCellValue('E'.$num, $v['uid']);
//                  $objActSheet->setCellValue('F'.$num, $v['uid']);
//                  $objActSheet->setCellValue('G'.$num, $v['uid']);
//                  $objActSheet->setCellValue('H'.$num, $v['uid']);
//                  $objActSheet->setCellValue('I'.$num, $v['uid']);
//                  $objActSheet->setCellValue('J'.$num, $v['uid']);
//                  $objActSheet->setCellValue('K'.$num, $v['uid']);
//                  $objActSheet->setCellValue('L'.$num, $v['uid']);
//                  $objActSheet->setCellValue('M'.$num, $v['uid']);
//                  $objActSheet->setCellValue('N'.$num, $v['uid']);
//
                    $objActSheet->setCellValue('O'.$num, $v['technology']);
                    $objActSheet->mergeCells('O'.$num.':O'.$stop);
                    $objActSheet->setCellValue('P'.$num, $v['application']);
                    $objActSheet->mergeCells('P'.$num.':P'.$stop);
                    $objActSheet->setCellValue('Q'.$num, $v['nature']);
                    $objActSheet->mergeCells('Q'.$num.':Q'.$stop);
                    $objActSheet->setCellValue('R'.$num, $v['established']);
                    $objActSheet->mergeCells('R'.$num.':R'.$stop);
                    $objActSheet->setCellValue('S'.$num, $v['employees']);
                    $objActSheet->mergeCells('S'.$num.':S'.$stop);
                    $objActSheet->setCellValue('T'.$num, $v['address']);
                    $objActSheet->mergeCells('T'.$num.':T'.$stop);
                    $objActSheet->setCellValue('U'.$num, $v['phone']);
                    $objActSheet->mergeCells('U'.$num.':U'.$stop);
                    $objActSheet->setCellValue('V'.$num, $v['fax']);
                    $objActSheet->mergeCells('V'.$num.':V'.$stop);
                    $objActSheet->setCellValue('W'.$num, $v['email']);
                    $objActSheet->mergeCells('W'.$num.':W'.$stop);
                    $objActSheet->setCellValue('X'.$num, $v['website']);
                    $objActSheet->mergeCells('X'.$num.':X'.$stop);
                    $objActSheet->setCellValue('Y'.$num, $v['longitude']);
                    $objActSheet->mergeCells('Y'.$num.':Y'.$stop);
                    $objActSheet->setCellValue('Z'.$num, $v['latitude']);
                    $objActSheet->mergeCells('Z'.$num.':Z'.$stop);
                    $objActSheet->setCellValue('AA'.$num, $v['park']);
                    $objActSheet->mergeCells('AA'.$num.':AA'.$stop);
                    $objActSheet->setCellValue('AB'.$num, $v['city']);
                    $objActSheet->mergeCells('AB'.$num.':AB'.$stop);
                    $objActSheet->setCellValue('AC'.$num, $v['description']);
                    $objActSheet->mergeCells('AC'.$num.':AC'.$stop);

                    //英文*************************************   
                    $en_start = $num + $total_rows;
                    $en_stop = $en_start - 1 + $total_rows;

                    $objActSheet->setCellValue('A'.$en_start, $v['uid']);
                    $objActSheet->mergeCells('A'.$en_start.':A'.$en_stop);
                    $objActSheet->setCellValue('B'.$en_start, $v['en_company']);
                    $objActSheet->mergeCells('B'.$en_start.':B'.$en_stop);
                    $objActSheet->setCellValue('C'.$en_start, $v['en_com']);
                    $objActSheet->mergeCells('C'.$en_start.':C'.$en_stop);
//
//                  $objActSheet->setCellValue('D'.$en_start, $v['com']);
//                  $objActSheet->setCellValue('E'.$en_start, $v['uid']);
//                  $objActSheet->setCellValue('F'.$en_start, $v['uid']);
//                  $objActSheet->setCellValue('G'.$en_start, $v['uid']);
//                  $objActSheet->setCellValue('H'.$en_start, $v['uid']);
//                  $objActSheet->setCellValue('I'.$en_start, $v['uid']);
//                  $objActSheet->setCellValue('J'.$en_start, $v['uid']);
//                  $objActSheet->setCellValue('K'.$en_start, $v['uid']);
//                  $objActSheet->setCellValue('L'.$en_start, $v['uid']);
//                  $objActSheet->setCellValue('M'.$en_start, $v['uid']);
//                  $objActSheet->setCellValue('N'.$en_start, $v['uid']);
//
                    $objActSheet->setCellValue('O'.$en_start, $v['en_technology']);
                    $objActSheet->mergeCells('O'.$en_start.':O'.$en_stop);
                    $objActSheet->setCellValue('P'.$en_start, $v['en_application']);
                    $objActSheet->mergeCells('P'.$en_start.':P'.$en_stop);
                    $objActSheet->setCellValue('Q'.$en_start, $v['en_nature']);
                    $objActSheet->mergeCells('Q'.$en_start.':Q'.$en_stop);
                    $objActSheet->setCellValue('R'.$en_start, $v['established']);
                    $objActSheet->mergeCells('R'.$en_start.':R'.$en_stop);
                    $objActSheet->setCellValue('S'.$en_start, $v['employees']);
                    $objActSheet->mergeCells('S'.$en_start.':S'.$en_stop);
                    $objActSheet->setCellValue('T'.$en_start, $v['en_address']);
                    $objActSheet->mergeCells('T'.$en_start.':T'.$en_stop);
                    $objActSheet->setCellValue('U'.$en_start, $v['phone']);
                    $objActSheet->mergeCells('U'.$en_start.':U'.$en_stop);
                    $objActSheet->setCellValue('V'.$en_start, $v['fax']);
                    $objActSheet->mergeCells('V'.$en_start.':V'.$en_stop);
                    $objActSheet->setCellValue('W'.$en_start, $v['email']);
                    $objActSheet->mergeCells('W'.$en_start.':W'.$en_stop);
                    $objActSheet->setCellValue('X'.$en_start, $v['website']);
                    $objActSheet->mergeCells('X'.$en_start.':X'.$en_stop);
                    $objActSheet->setCellValue('Y'.$en_start, $v['longitude']);
                    $objActSheet->mergeCells('Y'.$en_start.':Y'.$en_stop);
                    $objActSheet->setCellValue('Z'.$en_start, $v['latitude']);
                    $objActSheet->mergeCells('Z'.$en_start.':Z'.$en_stop);
                    $objActSheet->setCellValue('AA'.$en_start, $v['en_park']);
                    $objActSheet->mergeCells('AA'.$en_start.':AA'.$en_stop);
                    $objActSheet->setCellValue('AB'.$en_start, $v['en_city']);
                    $objActSheet->mergeCells('AB'.$en_start.':AB'.$en_stop);
                    $objActSheet->setCellValue('AC'.$en_start, $v['en_description']);
                    $objActSheet->mergeCells('AC'.$en_start.':AC'.$en_stop);

                    $num += $company[$k]['total_rows'] * 2;                         //下一公司的起始行数
                }
            }
        }
        //*************************************   
        //设置单元格样式   
        //

        //设置主标题字体  
        $objStyleA1 = $objActSheet->getStyle('A1'); 
        $objFontA1 = $objStyleA1->getFont();   
        $objFontA1->setName('宋体');   
        $objFontA1->setSize(14);   
        //$objFontA1->setBold(false);   
        //$objFontA1->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE);   
        //$objFontA1->getColor()->setARGB('FF999999');   
        //************************************* 
        //设置表头字体   
        $objStyleA2 = $objActSheet->getStyle('A2:AC4');
        $objFontA2 = $objStyleA2->getFont();   
        $objFontA2->setName('Cambria');   
        $objFontA2->setSize(10);

        //设置填充颜色   
        $objFillA2 = $objStyleA2->getFill();   
        $objFillA2->setFillType(PHPExcel_Style_Fill::FILL_SOLID);   
        $objFillA2->getStartColor()->setARGB('B7B7B7');  

        //从指定的单元格复制样式信息.   
        //$objActSheet->duplicateStyle($objStyleA2, 'A2:AC4');
        //************************************* 
        //设置表格字体

        $objActSheet->getStyle('A1:AC'.($num-1))->getFont()->setName('Cambria');
        $objActSheet->getStyle('A1:AC'.($num-1))->getFont()->setSize(9);

        //显示网格线: 
        $objActSheet->setShowGridlines(true);

        //设置自动换行
        $objActSheet->getStyle('A1:AC'.($num-1))->getAlignment()->setWrapText(true);

        //所有垂直居中
        $objActSheet->getStyle('A1:AC'.($num-1))->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);

        //前4行水平居中
        $objActSheet->getStyle('A1:AC4')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

        //后面水平左对齐
        $objActSheet->getStyle('A5:AC'.($num-1))->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_LEFT);

        //设置单元格边框
        $objActSheet->getStyle('A1:AC'.($num-1))->getBorders()->getAllBorders()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
        $objActSheet->getStyle('A1:AC'.($num-1))->getBorders()->getAllBorders()->getColor()->setARGB('000000');

        //*************************************   
        //输出内容
        //下面的路径按照你PHPExcel的路径来修改 
        //   

        $outputFileName = "output.xlsx";
        //$outputFileName = "output.xls";
        //到文件   
        //$objWriter->save($outputFileName);   
        //or   
        //到浏览器   
        header("Content-Type: application/force-download");
        header("Content-Type: application/octet-stream");
        header("Content-Type: application/download");
        header('Content-Disposition:inline;filename="'.$outputFileName.'"');
        header("Content-Transfer-Encoding: binary");
        header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
        header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
        header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
        header("Pragma: no-cache");
        $objWriter->save('php://output');
    }
伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全員に返信(2)
Ty80

foreach的多少不是影响性能的主因,而你foreach很多次一个耗时很长的代码就会直接增加运行时间。

你修改代码后,好像遍历次数还比之前多了,你要检查程序的嵌套及循环体的合理性。

代码看上去比较乱,你要把功能分块并对块进行概要的注释,才容易让人阅读。

いいねを押す +0
大家讲道理
foreach($first_cate_array as $fkey => $fvalue){  
    //一级目录起始行数  
    $stapos = $num+$second_count;  
    $en_stapos = $stapos+$cate_count;  
    $second_stapos = 0;  
    foreach($cate as $ck=>$cv){  
        if($cv['parentid'] == $fvalue['id']){

这个循环是可以优化的
比如

$first_cate_array = array( 
    array('id'=>1), 
    array('id'=>2) 
);  
$cate = array(
    array('sid'=>1,'parentid'=>2), 
    array('sid'=>2,'parentid'=>4),
    array('sid'=>3,'parentid'=>2) 
);
$cate2 = array(
    2=>array(
        array('sid'=>1,'parentid'=>2),
        array('sid'=>3,'parentid'=>2)
    ), 
    4=>array('sid'=>2,'parentid'=>4) 
);

foreach ($first_cate_array as $k=>$v){
    if(!empty($cate2[$v['id']])){

    }
} 

把$cate转化成$cate2
适用于嵌套循环次数比较多,foreach($cate as $ck=>$cv){ 的循环就可以省去

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート