使用php的时候一定会遇到表格导入导出的功能吧,这里简单来解释一下PHP中PHPExcel的使用如何来导入导出数据。
首先要去PHPExcel官网下载
这是我项目中的phpexcel类库
先说一下导入 主要是要通过文件上传,然后获取到这个上传的文件 然后可以用PHPExcel的方法去读取文件的内容 并返回一个数组,然后拼装你要的数据进行数据库操作
这里我用的封装好的方法去读取的excel文件的数据
$filename 文件的地址 需要一个相对路径
$begin 从第几行开始读取 (这里一般是第二行 第一行基本是内容的标题或者描述)
$allColumn 数据最后一列的字母 比如第G列是最后的数据列 就传G
封装方法:
function excelImport($filename, $begin,$allColumn) {
Vendor('PHPExcel.PHPExcel');
//建立reader对象
$PHPReader = new PHPExcel_Reader_Excel2007();
if (!$PHPReader->canRead($filename)) {
$PHPReader = new PHPExcel_Reader_Excel5();
if (!$PHPReader->canRead($filename)) {
return array();
}
}
//建立excel对象,此时你即可以通过excel对象读取文件,也可以通过它写入文件
$PHPExcel = $PHPReader->load($filename);
/* * 读取excel文件中的第一个工作表 */
$currentSheet = $PHPExcel->getSheet(0);
/* * 取得最大的列号 */
// $allColumn = $currentSheet->getHighestColumn();
/* * 取得一共有多少行 */
$allRow = $currentSheet->getHighestRow();
$returnCell = '';
//循环读取每个单元格的内容。注意行从1开始,列从A开始
for ($rowIndex = $begin; $rowIndex <= $allRow; $rowIndex++) {
for ($colIndex = 'A'; $colIndex <= $allColumn; $colIndex++) {
$addr = $colIndex . $rowIndex;
$cell = $currentSheet->getCell($addr)->getValue();
if ($cell instanceof PHPExcel_RichText) {
//富文本转换字符串
$returnCell[$rowIndex][$colIndex] = $cell->__toString();
} else {
$returnCell[$rowIndex][$colIndex] = $cell;
}
}
}
return $returnCell;
}
读取后会输出一个数组,如下
获取到数据后使用循环取出里面的数据 完成后清空了一下数据数组
这是简单两列数据的导入 .
再来说一下导出
我也是使用的PHPExcel
这里是先创建一个表格第一行的标题数组和导出的文件名称
一个一维数组键名要对应 表格列的字母
下面是要拼装导出数据
这是一个二维数组 需要 每行对应响应的列的字母
这里给了一个key值来确定数据是从第几行开始写入的
因为有标题的存在所以是从第二行开始如正式数据,
使用下面这个封装的导出方法进行导出 ,会自动使用浏览器下载你要导出的表格
这里也封装了一个导出的方法
/**
* 导出成Excel文件
* @param type $filename 文件名
* @param type $data_title 头部字段
* @param type $data_content 内容
* @param type $Sheet1
* @param type $save_to_file 是否保存成文件,true保存
* @param type $save_path 文件保存路径
*/
function excelExport($filename, $data_title, $data_content, $Sheet1 = "Sheet1", $save_to_file = false, $save_path = './Static/File/') {
Vendor('PHPExcel.PHPExcel');
//PHPExcel支持读模版 所以我还是比较喜欢先做好一个Excel的模版 比较好,不然要写很多代码 模版我放在根目录了
//创建一个对象
$objPHPExcel = new PHPExcel();
$objPHPExcel->getProperties()->setCreator("qiandai");
//获取当前活动的表
$objActSheet = $objPHPExcel->setActiveSheetIndex(0);
$objActSheet->setTitle($Sheet1); //工作表标签
foreach ($data_title as $data_title_key => $data_title_value) {//写入文件表头内容
$objActSheet->setCellValue($data_title_key.'1', $data_title_value);
$objPHPExcel->getActiveSheet()->getColumnDimension($data_title_key)->setWidth(30);//设置列的宽度
}
//现在就开始填充数据了 (从数据库中) $data_content
foreach ($data_content as $data_content_value) {//写入 文件内容
foreach ($data_content_value as $data_content_key => $data_content_value2) {
$objActSheet->setCellValue($data_content_key, $data_content_value2);
}
}
//导出
header('Content-Type: application/vnd.ms-excel;charset=utf-8');
header('Content-Disposition: attachment;filename="' . $filename . '.xls"');
header('Cache-Control: max-age=0');
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
if ($save_to_file) {
$objWriter->save($save_path . $filename);
} else {
$objWriter->save('php://output');
exit;
}
}
如果有什么方法不清楚或者想修改表格的其他设置的可以去查看手册进行添加。
导入导出主要还是明白封装的方法和创建对应的数组,希望能对刚接触到表格导入导出无法入手的人有所帮助。