行使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;
}
}
假定有甚么方式不清晰大概想批改表格的其他设置的能够去检查手册举行增加。
导入导出重要照样晓畅封装的方式和建立对应的数组,盼望能对刚打仗到表格导入导出没法动手的人有所赞助。