tp5.1 phpspreadsheet- 工具类 导入导出(整合优化,非原创,抄一抄,加了一些自己的东西,)
phpspreadsheet-工具类 导入导出(整合优化,非原创,抄一抄,加了一些自己的东西)
1. composer require phpoffice/phpspreadsheet
2. 看最下面的两个demo (使用框架 : tp5.1 , laravel也能用,改改不就行了..)
<?php
namespace app\common\utils; use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
use PhpOffice\PhpSpreadsheet\IOFactory; /**
* phpoffice-phpspreadsheet-工具类
*/
class PhpOffice{ /**
* @title 导出表格
* @param arr:要导出excel表的数据,接受一个二维数组
* @param fileName:excel表的表名
* @param headAr:excel表的表头,接受一个一维数组
* @param keyAr:$arr中对应表头的键的数组,接受一个一维数组
*/
public function exportExcel($fileName='表格', $arr=[], $headAr=[], $keyAr=[]){
$count = count($headAr)-1;//计算所需表头数量 $spreadsheet = new Spreadsheet();
$sheet = $spreadsheet->getActiveSheet(); //设置列
$rowAr=self::setRowAr($count);
foreach ($rowAr as $k => $v) {
if($k>$count) break;
$sheet->setCellValue($v.'1',$headAr[$k]);
} //写入值
foreach ($arr as $k => $v) {
foreach ($rowAr as $ke => $ve){
if($ke>$count) break;
$sheet->setCellValue($ve.($k+2),$v[$keyAr[$ke]]);
$spreadsheet->getActiveSheet()->getColumnDimension($ve)->setWidth(10); //固定列宽
}
}
//冻结首行
$spreadsheet->getActiveSheet()->freezePaneByColumnAndRow(0,2); //在输出Excel前,缓冲区中处理BOM头
ob_end_clean();
ob_start(); header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="'.$fileName.date('_Ymd_Hi',time()).'.xlsx"');
header('Cache-Control: max-age=0');
$writer = new Xlsx($spreadsheet);
$writer->save('php://output'); //删除清空:
$spreadsheet->disconnectWorksheets();
unset($spreadsheet);
exit;
} //导入
public function importExcel(){
set_time_limit(0); //文件上传导入
// $fileController=new FileController();
$res=self::uploadFileImport();
$data=$res['data'];
//手动输入路径
// $data='muban/muban.xlsx'; //修正路径
$filename=str_replace('/uploads', 'uploads',$data);
//进行读取
$spreadsheet = IOFactory::load($filename);
$sheetData = $spreadsheet->getActiveSheet()->toArray(null, true, true, true);
return $sheetData;
} //文件上传,导入文件专用,数据不入库
public function uploadFileImport(){
// 获取表单上传文件
$file = \request()->file('file');
$return = array('status' => 1, 'info' => '上传成功', 'data' => []);
// 移动到框架应用根目录/public/uploads/ 目录下
if($file){
$savePath = '/uploads/importExcel';
$info = $file->move(ROOT_PATH . 'public' . DS .$savePath);
$md5 = $info->hash('md5');
$sha1= $info->hash('sha1');
$saveName=strtr($info->getSaveName(),'\\','/');
return self::setResAr(1,'上传成功',$savePath.'/'.$saveName);
}
return self::setResAr(0,'上传失败');
} //设置列一维数组(最多701列)
public function setRowAr($count=26){
$indData='A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z';
$indData=explode(',',$indData);
$curCount=26;
for ($i=0; $i <26 ; $i++) {
for ($j=0; $j <26 ; $j++) {
if($curCount>=$count) return $indData;
$indData[]=$indData[$i].$indData[$j];
$curCount++;
}
}
return $indData;
} //设置返回结果格式
public function setResAr($code=0,$msg='',$data=array()){
return ['code'=>$code,'msg'=>$msg,'data'=>$data];
} // 如何实现..
// //定义好命名空间
// use app\common\utils\PhpOffice;
// use think\Db; // class Demo{
// //导出demo-实现
// public function exportDemo(){
// //获取数据
// $data=Db::name('config')->select();
// //获取表头(自行定义)
// $sql="select COLUMN_NAME as name,column_comment as val from INFORMATION_SCHEMA.Columns where table_name='表名'";
// $arr=Db::query($sql); // $headAr=[];
// $keyAr=[];
// foreach ($arr as $k => $v) {
// $headAr[]=$v['val'];
// $keyAr[]=$v['name'];
// }
// $phpOffice = new PhpOffice();
// $phpOffice->exportExcel('导出表格',$data,$headAr,$keyAr);
// } // //导入demo-实现
// public function importDemo(){
// $phpOffice = new PhpOffice();
// $data=$phpOffice->importExcel();
// dump($data);
// //自行foreach进行数据处理..
// //..
// }
// }
// }
<?php
//定义好命名空间
use app\common\utils\PhpOffice;
use think\Db; class Demo{ //导出demo-实现
public function exportDemo(){
//获取数据
$data=Db::name('config')->select();
//获取表头(自行定义)
$sql="select COLUMN_NAME as name,column_comment as val from INFORMATION_SCHEMA.Columns where table_name='表名'";
$arr=Db::query($sql); $headAr=[];
$keyAr=[];
foreach ($arr as $k => $v) {
$headAr[]=$v['val'];
$keyAr[]=$v['name'];
}
$phpOffice = new PhpOffice();
$phpOffice->exportExcel('导出表格',$data,$headAr,$keyAr);
} //导入demo-实现
public function importDemo(){
$phpOffice = new PhpOffice();
$data=$phpOffice->importExcel();
dump($data);
//自行foreach进行数据处理..
//..
}
}
?>
tp5.1 phpspreadsheet- 工具类 导入导出(整合优化,非原创,抄一抄,加了一些自己的东西,)的更多相关文章
- java工具类POI导出word
1.新建一个word,里面填写内容,如: 2.导出wordjava类 /** * POI导出word测试 * @throws Exception */ @RequestMapping(value=&q ...
- 【工具】导入导出 Excel
文章目录 前言 当前支持的功能 方法api 配置 如何使用(Demo) 实现思路(该工具类可正确的一个大前提) 后记 前言 之前写的项目中,有个需求,需要导出导入Excel表格: 本来很简单的一件事, ...
- 工具类--Excel 导出poi
实现功能 --批量导出excel 文件,配置一个sheet多少条数据,根据查询数据量的多少确定生成几个sheet页. pom 文件导入ExcelUtils工具包,依赖于poi包. <!-- ht ...
- 使用hutool工具类进行导出
引入依赖为: <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</ ...
- java excel大数据量导入导出与优化
package com.hundsun.ta.utils; import java.io.File; import java.io.FileOutputStream; import java.io.I ...
- Lucene第二篇【抽取工具类、索引库优化、分词器、高亮、摘要、排序、多条件搜索】
对Lucene代码优化 我们再次看回我们上一篇快速入门写过的代码,我来截取一些有代表性的: 以下代码在把数据填充到索引库,和从索引库查询数据的时候,都出现了.是重复代码! Directory dire ...
- java最全的获取某个接口或者某个类所有对应的所有实现类和继承类的工具类--反射动态获取、非动态获取、按照路径获取等总结
我们直接上代码吧,代码中有注释说明. //直接看代码吧 import java.io.File; import java.lang.reflect.Field; import java.net.URL ...
- 集合框架-工具类-Collections-其他方法将非同步集合转成同步集合的方法
集合框架TXT Collections-其他方法将非同步集合转成同步集合的方法
- Java基础学习总结(49)——Excel导入导出工具类
在项目的pom文件中引入 <dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifac ...
随机推荐
- 【剑指offer】Q16:翻转链表
def reverse(head): if head == None or head.next == None: return head psuhead = ListNode(-1) while he ...
- Linux常用指令全集
Linux简介及Ubuntu安装 常见指令 系统管理命令 打包压缩相关命令 关机/重启机器 Linux管道 Linux软件包管理 vim使用 用户及用户组管理 文件权限管理 大牛笔记-www.weix ...
- 【问题解决方案】GitHub上克隆项目到本地
说明: 克隆线上项目到本地,可以直接clone克隆,不必再自己建文件夹啊,初始化啊. 命令: git clone + 想要克隆的项目的地址 END
- JSP学习(1)
JSP学习(1) 什么是Web应用程序 可以Web访问呢的应用程序,用户只需要浏览器即可访问 静态网页与动态网页 静态网页:网页中内容固定 动态网页:内容通过程序动态显示,自动更新 Java Web应 ...
- 安装kali linux 后出现文字乱码问题
在安装kali时我选择中文安装,结果安装完成后出现文字乱码现象 在经过上网查询后,采用了CSDN博客站中的 stubbornness1219 这位博主的解决方案成功将问题解决. 解决方案:终端下执行s ...
- Codeforces Round #340 (Div. 2) E. XOR and Favorite Number (莫队)
题目链接:http://codeforces.com/contest/617/problem/E 题目大意:有n个数和m次查询,每次查询区间[l, r]问满足ai ^ ai+1 ^ ... ^ aj ...
- Mybatis学习笔记大纲
Mybatis学习笔记大纲: 一.MyBatis简介 二.MyBatis-HelloWorld 三.MyBatis-全局配置文件 四.MyBatis-映射文件 五.MyBatis-动态SQL 六.My ...
- Kettle连接MySQL错误:OPTION SQL_SELECT_LIMIT=DEFAULT
由于升级了MySQL到5.6,运行ETL报错: OPTION SQL_SELECT_LIMIT=DEFAULT 上网查询原来是MySQL的驱动版本不一致,之前的驱动不支持这样的写法,于是上网下载对应的 ...
- python基本数据预处理语法函数(2)
1.字符串格式化方法format的用法: < ^ > #分别为左对齐.居中.右对齐 '{:>18,.2f}'.format(70305084.0) #:冒号+空白填充+右对齐+固定宽 ...
- centos7标准版命令界面和图形界面相互切换
1.root登陆终端 2.输入命令 vi /etc/inittab ,查看两种界面的启动模式: 3.退出vi模式,,输入命令systemctl get-default 查看当前系统启动模式:我的是命令 ...