duanlang0025 2016-05-23 07:00
浏览 73

PHP to excel导致浏览器崩溃几次

I am trying to load a large Excel file from the Database . But since my user base has increased ,

The server is giving 500 error multiple time .

It did download the excel but it takes almost 10 - 20 failed attempt to download

here is my code

ini_set('memory_limit', '-1');
require(app_path().'/libs/excel/Classes/PHPExcel.php');
$objPHPExcel = new PHPExcel();

// Set document properties
$objPHPExcel->getProperties()->setCreator("ideconnect.com")
                             ->setLastModifiedBy("ideconnect.com")
                             ->setTitle("Office 2007 XLSX Test Document")
                             ->setSubject("Office 2007 XLSX Test Document")
                             ->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")
                             ->setKeywords("office 2007 openxml php")
                             ->setCategory("Test result file");


// Add some data
//***************************************************************************************
$arr = array();
// $firstpass=true;
// $projectscheckboxgroupadded=false;
// $prequestiongroup = '';


    if($exceleve =="Rescom Summit Bangalore 2016")
        $qid1 = "1";
    if($exceleve =="Rescom Summit Middle East 2016")
        $qid1="7297";

        if($exceleve =="Design Mission Saudi Arabia 2016")
        $qid1 = "325";

        if($exceleve =="Design Mission Middle East 2016")
        $qid1 = "649";

        if($exceleve =="Design Mission India 2016")
        $qid1 = "973";

        if($exceleve =="Design Mission Turkey 2016")
        $qid1 = "1297";

        if($exceleve =="Design Mission Africa 2016")
        $qid1 = "1945";

        if($exceleve =="Smart Education India 2016")
        $qid1 = "2269";

        if($exceleve =="Hotelier Summit Africa 2016")
        $qid1 = "2593";

        if($exceleve =="Hotelier Summit Middle East 2016") 
        $qid1 = "3889";


        if($exceleve =="Pharmac India 2016")
        $qid1 = "2917";

        if($exceleve =="Hotelier Summit India 2016")
        $qid1 = "3241";

        if($exceleve =="Healthscape Series Africa 2016")
        $qid1 = "4537";

        if($exceleve =="Healthscape Series India 2016")
        $qid1 = "5185";

        if($exceleve =="Healthscape Series Saudi Arabia 2016")
        $qid1 = "6157";

        if($exceleve =="Design Mission Asia 2016")
        $qid1 = "6502";

        //dd($qid1);

        $users1 = User::where('event','=',$exceleve)->orderby('name')->with(array('answer'=>function($q) use($qid1){

            $q->where('question_id','=',$qid1)->orWhere('question_id','=',$qid1+1);

        }))->get();


//dd($users1);

$user_ids=array();
foreach($users1 as $us){
    if($us->answer[0]->answer_text!='' && ($us->role!='admin_dd' || $us->role!='sales_dd')){
        $user_ids[] = $us->id;
    }
}



$useransarr = array();
$users = User::whereIn('id', $user_ids)->get();

 //$x = User::where('id','1648')->with('answer')->get();
 //dd($x);
//foreach ($user_ids as $value) {
    # code...
// $user_id = array();
//      array_push($user_id,1680);
//      array_push($user_id,1676);

//This FUcking page is taking lot of Mwemory so I gave ini_set('memory_limit', '-1');
    $userswithanswers = User::whereIn('id', $user_ids)
                    ->with('answer')
                    ->get();
//}//


// dd($userswithanswers);
foreach($userswithanswers as $usa){

    $tempansarr = array();
    $tempcatansarr = array();

    foreach($usa->answer as $ansobj){
        $tempansarr[$ansobj->question_id] = $ansobj->answer_text;
    }

    foreach($usa->categoryvendoranswer as $catansobj){
        $tempcatansarr[$catansobj->categoryvendor_id] = $catansobj->answer;
    }

    $useransarr[$usa->id]['login'] = $usa->email;
    $useransarr[$usa->id]['id'] = $usa->id;
    $useransarr[$usa->id]['answers'] = $tempansarr;
    $useransarr[$usa->id]['catanswers'] = $tempcatansarr;
 //dd($tempcatansarr);
}


 //dd($userswithanswers);
// $questions = Question::all();
// $users = User::whereIn('id', $user_ids)->get();

$questions = Question::orderBy('page')->where('event' ,'=',$exceleve)->where('page' ,'!=',0)->orderBy('order')->get();
//$categoryvendors = Categoryvendor::all();


// HEADER ROW FOR FOR EXCEL
$header1 = array();$header1[]='';
$header2 = array();$header2[]='Login';
$preprojectnumber = '';

foreach($questions as $header){
    /*echo $header->class_name."<br>";
    echo $header->question_group."<br>";*/
    $header3[] = "Page_".$header->page;
    if($header->class_name !='projects checkbox group'){
        //echo "1";
        $header1[] = $header->question_group;
        $header2[] = $header->question_text;

    } else {
        if($header->question_group!=$preprojectnumber){
            $header1[] = $header['question_group'];
            $header2[] = 'Stage of Buying Cycle';

        }
        $preprojectnumber = $header->question_group;

    }

}

 //dd($questions);

//************************
$excelarr = array();
//dd($useransarr);


foreach($useransarr as $usarr){

        $b=array();
        $b[]=$usarr['login'];
        $preprojectnumber = '';
        $tempvar = '';
        $counter=0;

// dd($usarr['answers']);

    foreach($questions as $question){
            if($question->class_name!='projects checkbox group'){ 
                $b[] = $usarr['answers'][$question->id];
            } 
            else 
            {
                if($question->question_group!=$preprojectnumber){
                    $counter=1;
                    $tempvar = $usarr['answers'][$question->id];
                    if($usarr['answers'][$question->id]!=''){$tempvar = $tempvar.', ';}
                } else {
                    $tempvar = $tempvar.$usarr['answers'][$question->id];
                    if($usarr['answers'][$question->id]!=''){$tempvar = $tempvar.', ';}
                }
                    $preprojectnumber = $question->question_group;
                    $counter++;
                    if($counter==5){
                            $b[]=$tempvar;
                    }
            }
    }

    //dd('sdfs');
/**
    $vendorstring='';
    foreach($categoryvendors as $catven){
        if(isset($usarr['catanswers'][$catven->id])){
            if($usarr['catanswers'][$catven->id]=='yes'){
                $vendorstring = $vendorstring.$catven->vendorname.', ';
            }
        }
    }
    $b[]=$vendorstring;**/

    $excelarr[] = $b;
    // var_dump($b);
    // print_r($usarr['catanswers']);
    // echo('<br/><br/>');
}

array_unshift($excelarr, $header1);
array_unshift($excelarr, $header2);
//array_unshift($excelarr, $header3);

if($exceleve=="Healthscape Series Saudi Arabia 2016")
$exceleve = "Healthscape Saudi";


$objPHPExcel->setActiveSheetIndex(0)
            ->fromArray($excelarr, '', 'A1');


if($exceleve =="Design Mission Saudi Arabia 2016")
    $exceleve ="Design Mission Saudi 2016";

if($exceleve =="Design Mission South Africa 2016")
    $exceleve ="Design Mission Africa 2016";

$objPHPExcel->getActiveSheet()->setTitle($exceleve);

$styleArray = array(
      'font' => array(
        'name' => 'Calibri',
        'size' => '10',
        'color' => array(
            'rgb' => 'FFFFFF'
        ),
        'bold' => true,
      ),
      'fill' => array(
        'type' => PHPExcel_Style_Fill::FILL_SOLID,
        'startcolor' => array(
          'rgb' => '000000',
        ),
      ),
    );


$styleArray2 = array(
      'font' => array(
        'name' => 'Calibri',
        'size' => '10',
        'color' => array(
            'rgb' => '000000'
        ),
        'bold' => true,
      ),

      'fill' => array(
        'type' => PHPExcel_Style_Fill::FILL_SOLID,
        'startcolor' => array(
          'rgb' => 'cccccc',
        ),
      ),
    );

$styleArray3 = array(
      'font' => array(
        'name' => 'Calibri',
        'size' => '8',
        ),
    );


$objPHPExcel->setActiveSheetIndex(0)->getDefaultStyle()->applyFromArray($styleArray3);
$objPHPExcel->setActiveSheetIndex(0)->getStyle('A2:LA2')->applyFromArray($styleArray2);
$objPHPExcel->setActiveSheetIndex(0)->getStyle('A1:LA1')->applyFromArray($styleArray);

$objPHPExcel->setActiveSheetIndex(0);

header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="event-data.xlsx"');
header('Cache-Control: max-age=0');


$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');


 // dd('aaa');
//ob_end_clean();
$objWriter->save('php://output');

Thanks

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
    • ¥15 用windows做服务的同志有吗
    • ¥60 求一个简单的网页(标签-安全|关键词-上传)
    • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
    • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
    • ¥100 为什么这个恒流源电路不能恒流?
    • ¥15 有偿求跨组件数据流路径图
    • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
    • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
    • ¥15 一直显示正在等待HID—ISP