2016-10-25 23 views

答えて

0

このコードを試してみてください。

function convertToCSV($data, $options) { 

     // setting the csv header 
     if (is_array($options) && isset($options['headers']) && is_array($options['headers'])) { 
      $headers = $options['headers']; 
     } else { 
      $headers = array(
       'Content-Type' => 'text/csv', 
       'Content-Disposition' => 'attachment; filename="ExportFileName.csv"' 
      ); 
     } 

     $output = ''; 

     // setting the first row of the csv if provided in options array 
     if (isset($options['firstRow']) && is_array($options['firstRow'])) { 
      $output .= implode(',', $options['firstRow']); 
      $output .= "\n"; // new line after the first line 
     } 

     // setting the columns for the csv. if columns provided, then fetching the or else object keys 
     if (isset($options['columns']) && is_array($options['columns'])) { 
      $columns = $options['columns']; 
     } else { 
      $objectKeys = get_object_vars($data[0]); 
      $columns = array_keys($objectKeys); 
     } 

     // populating the main output string 
     foreach ($data as $row) { 
      foreach ($columns as $column) { 
       $output .= str_replace(',', ';', $row->$column); 
       $output .= ','; 
      } 
      $output .= "\n"; 
     } 

     // calling the Response class make function inside my class to send the response. 
     // if our class is not a controller, this is required. 
     return Response::make($output, 200, $headers); 
    } 

出典:http://www.amitavroy.com/justread/content/articles/creating-csv-output-database-query-result-laravel-4/

+0

友人に感謝します。私はそのmaatwebsitがdocumnetationを凌駕する答えを見つける。 –

0
  1. myexcelは
  2. $これが配列のエクセル

    にエクスポートする内容を含んでいるresponse_arrayエクセル
  3. の名前です
    Excel::create('myexcel', function($excel) use($response_array) { 
    
        $excel->sheet('Sheet 1', function($sheet) use($response_array) { 
    
         $sheet->fromArray($response_array); 
        }); 
    
    })->export('xls'); 
    
関連する問題