~~~
<?php
/**
* Created by PhpStorm.
* Power By Mikkle
* Email:776329498@qq.com
* Date: 2017/8/8
* Time: 12:58
*/
namespace app\base\controller;
use think\Db;
use think\Exception;
use think\Loader;
class Excel
{
/**
* TP5 Excel專用類庫
* $excel=new Excel();
* $table_name="mk_material_list_edit";
* $field=["id"=>"序號","guid"=>"項目代碼","name"=>"項目名稱"];
* $map=["status"=>1];
* $map2=["status"=>-1];
* $excel->setExcelName("下載裝修項目")
* ->createSheet("裝修項目",$table_name,$field,$map)
* ->createSheet("已刪除裝修項目",$table_name,$field,$map2)
* ->downloadExcel();
*
* Power: Mikkle
* Email:776329498@qq.com
* @var \PHPExcel
*/
protected $objPHPExcel;
public $xlsReader;
public static $instance;
protected $sheetNum=0;
protected $error;
protected $columnWidth;
protected $rowHeight=20;
protected $excelName;
protected $isLoad=false;
//如果你的字段列數超過26字母 會報錯
protected $letterArray=["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"];
/**
* 項目初始化
* Excel constructor.
*/
public function __construct()
{
Loader::import("com/PHPExcel/PHPExcel");
$this->objPHPExcel=new \PHPExcel();
if(!$this->isLoad){
//新建時刪除默認頁面
$this->objPHPExcel->disconnectWorksheets();
}
}
/**
* Power: Mikkle
* Email:776329498@qq.com
* @param string $path
* @return static
* @throws Exception
* @throws \PHPExcel_Reader_Exception
*/
static public function loadExcel($path="/test.xls"){
if (is_null(self::$instance)) {
self::$instance = new static();
}
$path=ROOT_PATH."public_html/".$path;
$excel = self::$instance;
try {
try {
$xlsReader = \PHPExcel_IOFactory::createReader("Excel2007");
$xlsReader->setReadDataOnly(true); //
$xlsReader->setLoadSheetsOnly(true);
$excel->xlsReader=$xlsReader->load($path);
} catch (Exception $e) {
$xlsReader = \PHPExcel_IOFactory::createReader("Excel5");
$xlsReader->setReadDataOnly(true); //
$xlsReader->setLoadSheetsOnly(true);
$excel->xlsReader=$xlsReader->load($path);
}
} catch (Exception $e) {
throw new Exception("讀取EXCEL失敗");
}
return $excel;
}
public function getSheetByName($name){
if (isset($this->xlsReader)){
return $this->xlsReader->getSheetByName($name);
}else{
return false;
}
}
public function getSheetNames(){
if (isset($this->xlsReader)){
return $this->xlsReader->getSheetNames();
}else{
return false;
}
}
/**
* Power: Mikkle
* Email:776329498@qq.com
* @return mixed
*/
public function getExcelObject(){
return $this->xlsReader;
}
public function getAllSheets(){
if (isset($this->xlsReader)){
return $this->xlsReader->getAllSheets();
}else{
return false;
}
}
public function getSheetCount(){
if (isset($this->xlsReader)){
return $this->xlsReader->getSheetCount();
}else{
return false;
}
}
public function getSheetArrayByIndex($index=0){
if (isset($this->xlsReader)){
return $this->xlsReader->getSheet($index)->toArray();
}else{
return false;
}
}
/**
* 設置下載的Excel名稱
* Power: Mikkle
* Email:776329498@qq.com
* @param $name
* @return $this
*/
public function setExcelName($name){
$this->excelName=$name;
return $this;
}
/**
* 返回EXCEL名稱
* Power: Mikkle
* Email:776329498@qq.com
* @return string
*/
public function getExcelName()
{
return $this->excelName ? $this->excelName : "新建的數據表格";
}
/**
* 創建新的Sheet 支持鏈式操作
* Power: Mikkle
* Email:776329498@qq.com
* @param string $sheet_title
* @param string $table 數據庫表名稱
* @param array $field 要導出的字段
* @param array $map 查詢參數
* @return $this
* @throws Exception
* @throws \PHPExcel_Exception
*/
public function createSheet($sheet_title="sheet",$table="",$field=[],$map=[]){
if (empty($table) ||empty($field)||!is_string($table)||!is_array($field)){
$this->error="生成Excel的[table]或[field]參數不正確";
throw new Exception("生成Excel的[table]或[field]參數不正確");
return $this;
}
$sheet_num = $this->getNewSheetNum();
$objPHPExcel=$this->objPHPExcel;
$objPHPExcel->createSheet($sheet_num);
$objPHPExcel->setActiveSheetIndex($sheet_num);
$objPHPExcel->getActiveSheet()->setTitle($sheet_title);
//設置默認行高
$objPHPExcel->getActiveSheet()->getDefaultRowDimension()->setRowHeight($this->rowHeight);
$sheet=$objPHPExcel->getActiveSheet();
$field_title=array_values($field);
$letter_array = $this->letterArray;
foreach($field_title as $item=>$value){
if(isset($this->columnWidth)){
if(is_array($this->columnWidth) && count($field)==count($this->columnWidth)){
$sheet->getColumnDimension($letter_array[$item])->setWidth($this->columnWidth[$item]);
}elseif(is_integer($this->columnWidth)){
$sheet->getColumnDimension($letter_array[$item])->setWidth($this->columnWidth);
}else{
$sheet->getColumnDimension($letter_array[$item])->setAutoSize(true);
}
}else{
$sheet->getColumnDimension($letter_array[$item])->setAutoSize(true);
}
//標題加粗
$sheet->getStyle($letter_array[$item]."1")->getFont()->setBold(true);
$sheet->setCellValue($letter_array[$item]."1",$value);
}
$list=Db::table($table)->field($field)->where($map)->select();
if ($list){
foreach($list as $item=>$value ){
$value=array_values($value);
foreach($value as $i=>$v)
$sheet->setCellValue($letter_array[$i].($item+2),$value[$i]);
}
}
return $this;
}
/**
* 通過model生成Excel 獲取器生效
* Power: Mikkle
* Email:776329498@qq.com
* @param string $sheet_title
* @param string $model_name
* @param array $field
* @param array $map
* @return $this
* @throws Exception
* @throws \PHPExcel_Exception
*/
public function createSheetByModel($sheet_title="sheet",$model_name="",$field=[],$map=[]){
if (empty($model_name) ||empty($field)||!is_string($model_name)||!is_array($field)){
$this->error="生成Excel的[table]或[field]參數不正確";
throw new Exception("生成Excel的[table]或[field]參數不正確");
return $this;
}
$sheet_num = $this->getNewSheetNum();
$objPHPExcel=$this->objPHPExcel;
$objPHPExcel->createSheet($sheet_num);
$objPHPExcel->setActiveSheetIndex($sheet_num);
$objPHPExcel->getActiveSheet()->setTitle($sheet_title);
//設置默認行高
$objPHPExcel->getActiveSheet()->getDefaultRowDimension()->setRowHeight($this->rowHeight);
$sheet=$objPHPExcel->getActiveSheet();
$field_title=array_values($field);
$letter_array = $this->letterArray;
foreach($field_title as $item=>$value){
if(isset($this->columnWidth)){
if(is_array($this->columnWidth) && count($field)==count($this->columnWidth)){
$sheet->getColumnDimension($letter_array[$item])->setWidth($this->columnWidth[$item]);
}elseif(is_integer($this->columnWidth)){
$sheet->getColumnDimension($letter_array[$item])->setWidth($this->columnWidth);
}else{
$sheet->getColumnDimension($letter_array[$item])->setAutoSize(true);
}
}else{
$sheet->getColumnDimension($letter_array[$item])->setAutoSize(true);
}
//標題加粗
$sheet->getStyle($letter_array[$item]."1")->getFont()->setBold(true);
$sheet->setCellValue($letter_array[$item]."1",$value);
}
$field=array_values(array_flip($field));
$list=Loader::model($model_name)->field($field)->where($map)->select();
if ($list){
foreach($list as $item=>$value ){
$value=array_values($value->toArray());
foreach($value as $i=>$v)
if (is_array($v)) {
$sheet->setCellValue($letter_array[$i].($item+2),implode("--",$v));
}else{
$sheet->setCellValue($letter_array[$i].($item+2),$v);
}
}
}
return $this;
}
/**
* 下載當前的EXCEL
* Power: Mikkle
* Email:776329498@qq.com
* @param string $save_name
* @throws \PHPExcel_Reader_Exception
*/
public function downloadExcel($save_name=""){
ob_start();
//最后通過瀏覽器輸出
$save_name=$this->getExcelName();
$save_name = $save_name ? "$save_name.xls" : "導出信息.xls";
header('Content-Type: application/vnd.ms-excel; charset=utf-8');
header("Content-Disposition: attachment;filename=$save_name");
header('Cache-Control: max-age=0');
$objWriter = \PHPExcel_IOFactory::createWriter($this->objPHPExcel, 'Excel5');
$objWriter->save('php://output');
ob_end_flush();//輸出全部內容到瀏覽器
die();
}
/**
* 獲取新的Sheet編號
* Power: Mikkle
* Email:776329498@qq.com
* @return int
*/
protected function getNewSheetNum(){
$sheet_num=$this->sheetNum;
$this->sheetNum=$sheet_num+1;
return $sheet_num;
}
/**
* 設置行寬 未設置時候默認為自動
* Power: Mikkle
* Email:776329498@qq.com
* @param $width
* @return $this
*/
public function setColumnWidth($width){
if(is_numeric($width)||is_array($width)){
$this->columnWidth=$width;
}
return $this;
}
/**
* 設置默認行高
* Power: Mikkle
* Email:776329498@qq.com
* @param $height
* @return $this
*/
public function setRowHeight($height){
if(is_integer($height)){
$this->rowHeight=$height;
}
return $this;
}
/**
* 魔術方法 有不存在的操作的時候執行
* @access public
* @param string $method 方法名
* @param array $args 參數
* @return mixed
*/
public function __call($method, $args)
{
call_user_func_array([$this->objPHPExcel, $method], $args);
}
}
~~~
- 序言及更新日志
- 前言一 開發PHP必備的環境(你可以不看)
- LinUX系統ThinkPHP5鏈接MsSQL數據庫的pdo_dblib擴展
- centos7.2掛載硬盤攻略
- Centos系統Redis安裝及Redis的PHP擴展安裝
- Centos系統增加Swap(系統交換區)的方法
- 前言二 開發PHP軟件配置和介紹(你依然可以不看)
- 數據庫SQL文件
- 本地Git(版本控制)的搭建
- GIT遠程倉庫的克隆和推送
- Git常用命令
- PHP面向對象思想實戰經驗領悟
- PHP面向對象實戰----命名空間
- PHP面向對象實戰----繼承
- 基類實戰--底層方法封裝
- 基類實戰--構造函數實戰
- 基類實戰--析構函數的使用
- TP5實戰開發前篇---控制器(controller)
- 控制器中Request類的使用
- 控制器中基類的使用
- TP5實戰開發前篇---模型篇(model)
- TP5實戰開發前篇---驗證器篇(Validate)
- TP5實戰課程入門篇---花拳繡腿
- 模塊以及類的文件的建立
- Api開發------單條信息顯示
- Api開發---單條信息復雜關聯顯示
- Api開發---查詢信息緩存Cache的應用
- TP5實戰技巧---開發思路 引路造橋
- TP5實戰技巧---整合基類 化繁為簡
- TP5實戰課程入門篇---數據操作
- Api開發---數據的添加和修改
- API開發---快速開發API通用接口
- TP5專用微信sdk使用教程
- THINKPHP5微信SDK更新記錄及升級指導
- TP5專用SDK 微信參數配置方法
- 微信公眾號推送接口對接教程
- 微信推送接口對接示例含掃描登錄微信端部分
- TP5專用微信支付SDK使用簡介
- TP5專用支付寶支付SDK使用說明
- 使用NW將開發的網站打包成桌面應用
- TP5高階實戰課程 進階篇概述
- 進階篇一 實戰開發之習慣及要求
- 進階篇二 實戰開發之控制器
- 控制器基類之控制器基類使用方法
- 控制器基類之控制器基類常用方法分享
- 控制器基類之構造函數的使用方法
- 進階篇三 實戰開發之權限控制
- TP5實戰源碼 --- 全局用戶信息驗證類Auth
- TP5實戰源碼 --- 微信Auth實戰開發源碼
- 進階篇四 實戰開發之模型
- 模型基類之模型基類的用途
- 模型基類之常用數據處理方法
- 模型邏輯層之實戰代碼(含事務)
- 模型實戰開發之模型常用方法
- 模型實戰源碼 --- 樂觀鎖的應用
- 模型實戰技巧---Model事件功能的使用
- 模型事件實戰應用---數據庫操作日志
- 進階篇五 實戰開發之緩存(Cache)
- TP5實戰源碼---應用緩存獲取城市信息
- TP5實戰源碼---應用緩存獲取分類詳情
- 進階篇六 TP5類庫的封裝和使用
- DataEdit快捷操作類庫
- ShowCode快捷使用類庫
- 阿里大于 短信API接口 TP5專用類庫
- DatabaseUpgrade數據庫對比及更新類庫
- AuthWeb權限類使用說明
- 進階篇七 服務層的應用
- 服務層源碼示例
- 服務層基類源碼
- 進階篇八 應用層Redis數據處理基類
- Redis服務層基類源碼
- 進階篇九 使用Redis類庫處理一般的搶購(秒殺)活動示例
- 進階篇十 某大型項目應用本Redis類源碼示例(含事務 樂觀鎖)
- 進階篇十一 邏輯層的應用
- 邏輯層基類源碼
- 進階篇 服務層代碼示例
- 高階實戰課程 進階篇持續新增中
- 高階篇一 TP5命令行之守護任務源碼
- TP5實戰源碼 --- 命令行
- TP5實戰源碼 --- 通過shell建立PHP守護程序
- 高階篇二 使用Redis隊列發送微信模版消息
- 高階篇二 之 Worker隊列基類源碼
- 高階篇三 TP5實戰之Redis緩存應用
- Redis實戰源碼之Hash專用類庫源碼
- Redis實戰源碼之Model類結合
- Redis實戰源碼之模型Hash基類源碼
- Redis實戰源碼之Hash查詢使用技巧
- Redis實戰源碼之 shell腳本中redis賦值和取值
- 高階篇四 Swoole的實戰應用
- swoole基類代碼
- Swoole擴展WebsocketServer專用類
- 基于Swoole的多Room聊天室的程序
- Swoole守護服務shell源碼
- 高階篇五 命令行異步多進程隊列類的應用
- tp_worker類源碼
- WorkerBase
- WorkerCommand
- WorkerRedis
- Redis類
- CycleWorkBase
- WorkerHookBase異步鉤子
- 隊列日志SQL
- 高階篇六 定時執行隊列類庫以及使用方法
- 定時隊列類庫源碼
- 高階篇七 異步執行循環隊列類庫以及使用教程
- CycleWorkBase源碼
- 高階實戰課程 進階篇持續新增中
- Extend便捷類庫源碼庫
- 阿里相關類庫
- SendSms--驗證碼API接口文件
- 權限相關類庫目錄
- AuthWeb 權限驗證類庫
- Redis便捷操作類庫(20171224更新)
- Redis
- Tools工具類庫集
- Curl類庫
- DataEdit
- Rand類庫
- ShowCode類庫
- Upload類庫
- 附件集合
- 附件一:微信支付 實戰開發源碼
- 微信支付類庫源代碼
- Common_util_pub.php
- DownloadBill_pub.php
- JsApi_pub.php
- NativeCall_pub.php
- NativeLink_pub.php
- OrderQuery_pub.php
- Refund_pub.php
- RefundQuery_pub.php
- SDKRuntimeException.php
- ShortUrl_pub.php
- UnifiedOrder_pub.php
- Wxpay_client_pub.php
- Wxpay_server_pub.php
- WxPayConf_pub.php
- 微信支付回調頁面源碼
- 附件二 順豐快遞BSP接口實戰開發源碼
- 順豐快遞BSP接口實戰開發源碼
- 順豐BSP基類
- 順豐BSP基礎代碼
- 順豐BSP下單接口
- 順豐BSP查單接口
- 順豐BSP確認/取消接口
- 附件三 APP注冊登陸接口源碼(含融云平臺接口)
- 附件四 TP5訂單Model(含事務 獲取器 修改器等方法)
- 附錄五 RSA加密解密
- Rsa文件源碼
- 附件六 阿里大于短信接口
- 附件七 AES加解密類
- AES加解密類源碼
- 附件八 TP5路由設置源碼
- 附件九 TP5 Excel導入導出下載便捷類庫
- Excel類庫TP5源碼
- 附件十 TP5便捷操作Redis類庫源碼
- TP5源碼 Redis操作便捷類庫
- 附件十一 TP5源碼 上傳文件入庫類源碼
- 上傳類Upload源碼
- Upload類上傳配置文件
- 存儲圖像文件的數據庫SQL文件
- 存儲文件的數據庫SQL文件
- 附件十二 TP5 圖片處理增強類 支持縮略圖在線顯示
- 附件十三 微信推送消息接口類庫源碼
- 附件十三 微信推送消息接口類庫源碼 之 基類
- 附件十四 存儲微信昵稱的處理方法