一聚教程网:一个值得你收藏的教程网站

热门教程

ThinkPHP中用PHPExcel导入导出Excel文件

时间:2022-06-25 02:31:48 编辑:袖梨 来源:一聚教程网

需要的PHPExcel类可以到网上下载然后引入到ThinkPHP框架中使用即可
本例中PHPExcel文件的路径位于/ThinkPHP/Extend/Vendor/Excel/PHPExcel

具体代码如下:

 代码如下 复制代码

class ExcelAction extends Action {

//导出Excel文件
public function index(){
header("Content-Typ:text/html;charset=utf-8");

vendor('Excel.PHPExcel.Writer.IWriter');
vendor('Excel.PHPExcel.Writer.Excel5');
vendor('Excel.PHPExcel');
vendor('Excel.PHPExcel.IOFactory');

$objPHPExcel = new PHPExcel();

$objPHPExcel->getActiveSheet()->setCellValue('A1', "编号");//设置列的值
$objPHPExcel->getActiveSheet()->setCellValue('B1', "姓名");//设置列的值
$objPHPExcel->getActiveSheet()->setCellValue('C1', "登录时间");//设置列的值

$arr=M('user')->order("id asc")->select();

$count = count($arr); //求出有多少行;
$i=2; //注意这是2;因为第一行我们已经设置了表头信息

for($j=0;$j<$count;$j++)
       {
$objPHPExcel->setActiveSheetIndex(0)
->setCellValue('A'.$i,$arr[$j]['id'])   //注意这里没有分号结束
->setCellValue('B'.$i,$arr[$j]['username'])
->setCellValue('C'.$i,date('Y-m-d H:i:s',$arr[$j]['logintime']));
$i++;
}

$objPHPExcel->getActiveSheet(0)->setTitle('user');
$objPHPExcel->setActiveSheetIndex(0);
header('Content-Type:application/vnd.ms-excel');
header('Content-Disposition:attachment;filename="user.xls"');
header('Cache-Control: max-age=0');
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');    
}

//导入Excel文件
public function importExcel(){
header("content-type:text/html;charset=utf-8");

vendor('Excel.PHPExcel');
vendor('Excel.PHPExcel.IOFactory');
vendor('Excel.PHPExcel.Reader.Excel5');

$objReader = new PHPExcel_Reader_Excel5;//注意和导出的类不一样哦

$objPHPExcel = $objReader->load('user.xls'); //上传的文件,或者是指定的文件
$sheet = $objPHPExcel->getSheet(0);
$highestRow = $sheet->getHighestRow(); //取得总行数
$highestColumn = $sheet->getHighestColumn(); //取得总列数

for($j=2;$j<=$highestrow;$j++)
       {
$name = $objPHPExcel->getActiveSheet()->getCell("B".$j)->getValue();//获取B列的值
$time = strtotime($objPHPExcel->getActiveSheet()->getCell("C".$j)->getValue());//获取C列的值

if(!M('user')->add(array('username'=>$name,'logintime'=>$time))){echo '失败';}

echo '成功';
}

}


?>


数据库数据:

word-spacing: 0px; padding-top: 0px; -webkit-text-size-adjust: auto; -webkit-text-stroke-">
ThinkPHP中用PHPExcel导入导出Excel文件

导出为Excel文件结果:

ThinkPHP中用PHPExcel导入导出Excel文件

导入后数据库数据:

ThinkPHP中用PHPExcel导入导出Excel文件

热门栏目