我正在尝试使用PHPExcel 1.7.8 + CodeIgniter 2.1.3导出XLS文件
我已按照PHPExcel
的所有说明操作但是我收到了这个错误:
无法加载请求的类:
iofactory
这是我的控制器代码:
//expoxt to excel all admin data
function export_excel_admin()
{
//$data['resultsadmin'] = $this->admin_model->get_all_data_admin();
//var_dump($data['resultsadmin']);
//$this->load->view('administrator/export_excel/export_excel_admin', $data);
$query = $this->db->get('tbl_admin');
if(!$query)
return false;
// Starting the PHPExcel library
$this->load->library('excel');
$this->load->library('PHPexcel/IOFactory');
$objPHPExcel = new PHPExcel();
$objPHPExcel->getProperties()->setTitle("export")->setDescription("none");
$objPHPExcel->setActiveSheetIndex(0);
// Field names in the first row
$fields = $query->list_fields();
$col = 0;
foreach ($fields as $field)
{
$objPHPExcel->getActiveSheet()->setCellValueByColumnAndRow($col, 1, $field);
$col++;
}
// Fetching the table data
$row = 2;
foreach($query->result() as $data)
{
$col = 0;
foreach ($fields as $field)
{
$objPHPExcel->getActiveSheet()->setCellValueByColumnAndRow($col, $row, $data->$field);
$col++;
}
$row++;
}
$objPHPExcel->setActiveSheetIndex(0);
$objWriter = IOFactory::createWriter($objPHPExcel, 'Excel5');
// Sending headers to force the user to download the file
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="Products_'.date('dMy').'.xls"');
header('Cache-Control: max-age=0');
$objWriter->save('php://output');
}
啊我也删除了IOFactory.php文件中的“PHPExcel_”部分 解决这个问题的任何方法?
答案 0 :(得分:8)
我之前已成功使用PHPExcel和CodeIgniter。
我所做的只是将phpexcel文件夹放入应用程序/第三方并创建了以下包装器库:
<?php
class Excel {
private $excel;
public function __construct() {
// initialise the reference to the codeigniter instance
require_once APPPATH.'third_party/phpexcel/PHPExcel.php';
$this->excel = new PHPExcel();
}
public function load($path) {
$objReader = PHPExcel_IOFactory::createReader('Excel5');
$this->excel = $objReader->load($path);
}
public function save($path) {
// Write out as the new file
$objWriter = PHPExcel_IOFactory::createWriter($this->excel, 'Excel5');
$objWriter->save($path);
}
public function stream($filename) {
header('Content-type: application/ms-excel');
header("Content-Disposition: attachment; filename=\"".$filename."\"");
header("Cache-control: private");
$objWriter = PHPExcel_IOFactory::createWriter($this->excel, 'Excel5');
$objWriter->save('php://output');
}
public function __call($name, $arguments) {
// make sure our child object has this method
if(method_exists($this->excel, $name)) {
// forward the call to our child object
return call_user_func_array(array($this->excel, $name), $arguments);
}
return null;
}
}
?>
然后我可以在我的控制器中执行以下操作:
$this->load->library("excel");
$this->excel->load("/path/to/input.xls");
$this->excel->setActiveSheetIndex(0);
$this->excel->getActiveSheet()->SetCellValue('B2', "whatever");
$this->excel->save("/path/to/output.xls");
希望这可以帮到你吗?
答案 1 :(得分:3)
也许这个评论为时已晚。但也许对其他人有用。
更改以下部件代码:
// Starting the PHPExcel library
$this->load->library('excel');
$this->load->library('PHPexcel/IOFactory');
为:
// Starting the PHPExcel library
$this->load->library('excel');
//$this->load->library('PHPexcel/IOFactory');
然后更改此部件代码:
$objWriter = IOFactory::createWriter($objPHPExcel, 'Excel5');
为:
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
答案 2 :(得分:0)
你需要的只是
//afrer this you can use any of PHPExcel classes and methods
$this->load->file(APPPATH.'libraries/PHPExcel.php'); //full path to
$objReader = new PHPExcel_Reader_Excel2007();//change by filetype
try {
$objPHPExcel = $objReader->load($inputFileName); //you file name
} catch (Exception $e) {
show_error($e->getMessage());
}
在CI 2.1.3&amp;&amp; PHPExcel 1.7.8
答案 3 :(得分:-1)
我按照这些说明进行CodeIgniter和PHPExcel之间的集成。
在CI的application/libraries/
中创建一个新的PHP文件,并将其命名为Excel.php。
require_once APPPATH."/third_party/PHPExcel.php";
class Excel extends PHPExcel {
public function __construct(){
parent::__construct();
}
}
要按照完整说明操作,请访问Easily Integrateload Phpexcel Into Codeigniter Framework。