來源:https://blog.csdn.net/qq_34625397/article/details/136225972
前提是已經安裝了phpspreadsheet ( composer require phpoffice/phpspreadsheet )
一、 數據拼裝,調用excel類
```
<?php
/**
* 電子臺賬
* Date: 2023/4/20
* Time: 17:28
*/
namespace app\store\controller;
use app\common\controller\Excel;
use app\common\model\ModelRedis;
use app\store\model\ModelSaleStoreInput;
class Ledger extends \app\ApiCommon
{
/**
* 導出數據拼裝
* @param $ids string 出庫id 列表 1,2,3,4
*/
public function export_input($ids,$start,$end){
$where = [];
if(!empty($start) && !empty($end)){
$where[] = ['ctime','>=',strtotime($start)];
$where[] = ['ctime','<=',strtotime($end)];
}else{
$where[] = ['id','in',$ids];
}
$list = ModelSaleStoreInput::where($where)->field($field)->select()->toArray();
if(empty($list)){
return $this->apiError('數據不存在');
}
$data = $list;
//此處說明:解決數字太長尾數變000的問題
//由于數字超過15位,會被顯示成0或者加小數點處理。造成這種情況是由于Excel內置的數值有效范圍是15位。超過15位,如果要顯示的話,就需要轉換成非數字格式。比如文本格式。
foreach ($data as $key => $value) {
$tmp = [];
$explode_no = self::decode_explode_no($value['explode_no']);
array_push($tmp,"\t".$value['id']."\t");
array_push($tmp,"\t".$value['ctime']."\t");
array_push($tmp,"\t".$value['store_name']."\t");
array_push($tmp,"\t".$value['name']."\t");
array_push($tmp,"\t".$value['spec_name']."\t");
array_push($tmp,"\t".$value['amount']."\t");
array_push($tmp,"\t".$explode_no."\t");
array_push($tmp,"\t".$value['supply_company']."\t");
array_push($tmp,"\t".$value['deliver']."\t");
array_push($tmp,"\t".self::desensitizedIdCard($value['deliver_idcard'])."\t");
array_push($tmp,"\t".$value['carry_no']."\t");
array_push($tmp,"\t".$value['buy_no']."\t");
array_push($tmp,"\t".$value['storeman_names']."\t");
array_push($tmp,"\t".$value['storeman_signs']."\t");
array_push($tmp,"\t".$value['safety_name']."\t");
array_push($tmp,"\t".$value['safety_sign']."\t");
$data[$key] = $tmp;
}
//保存到本地臨時目錄
$path = './uploads/tmp/';
$excel_name = '數據盤點';
$title = ['id','時間','倉庫名','物品名稱','品種規格','物品數量','編號','供貨單位','送貨人','身份證號','運輸證號','購買證號','庫管員','庫管員簽字','安全員','安全員簽字'];
$file_name = date('Y-m-d').rand(1000,9999).$excel_name.'.xlsx';
$res = Excel::export($title,$data,$path,$file_name);
return $res;
}
}
```
二、封裝好的Excel類:注意遠程圖片必須base64后緩存到本地再寫入excel。
```
<?php
/**
* excel導入導出公共類
* Date: 2023/4/27
* Time: 18:39
*/
namespace app\common\controller;
use PhpOffice\PhpSpreadsheet\Cell\Coordinate;
use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Worksheet\Drawing;
use think\exception\ValidateException;
use think\facade\Filesystem;
class Excel
{
/**
* 數據導出Excel
* @param array $title 表頭
* @param array $data 數據源
* @param string $path 目錄
* @param string $file_name 文件名稱
* @return array
*/
public static function export($title = [], $data = [],$path,$file_name="")
{
try{
$spreadsheet = new Spreadsheet();
$sheet = $spreadsheet->getActiveSheet();
// 表頭單元格內容 第一行
$titCol = 'A';
foreach ($title as $value) {
// 單元格內容寫入
$sheet->setCellValue($titCol . '1', $value);
$titCol++;
}
//單元格內容居中
$sheet->getDefaultRowDimension()->setRowHeight(60);//默認行高60
$sheet->getDefaultColumnDimension()->setAutoSize(true);//列寬自適應
$sheet->getStyle('A:'.$titCol)->getAlignment()->setVertical('center');//內容容垂居中
$sheet->getStyle('A:'.$titCol)->getAlignment()->setHorizontal('center');//內水平直居中
// 從第二行開始寫入數據
$row = 2;
foreach ($data as $item) {
$dataCol = 'A';
foreach ($item as $value) {
// 單元格內容寫入
$values = explode(".",$value);
$ext = trim(end($values));
if(in_array($ext,['jpg','png','jpeg'])){ //多圖導出
$num = 10;
$images = explode(',', $value);
foreach ($images as $k => $v) {
$drawings[$k] = new Drawing();
$img = self::img_resource(trim($v),$path,$k);
//圖片路徑,項目目錄下就行
$drawings[$k]->setResizeProportional(false);
$drawings[$k]->setName('手動簽名圖片');
$drawings[$k]->setDescription('手動簽名圖片展示');
$drawings[$k]->setPath($img,true);
$drawings[$k]->setWidth(60);
$drawings[$k]->setHeight(60);
$drawings[$k]->setOffsetX($num);
$drawings[$k]->setOffsetY(10);
$drawings[$k]->setCoordinates($dataCol . $row);
$drawings[$k]->setWorksheet($sheet);
$num = $num + 70; // 增加每張圖之間的間距
}
}else{
$sheet->setCellValue($dataCol . $row, $value);
}
//自適應列寬
$len = strlen($value);
if($len>1){ //空數據不做處理避免影響到有數據的列寬度
$sheet->getColumnDimension($dataCol)->setWidth($len);
}
$dataCol++;
}
$row++;
}
$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
if(is_file($path.$file_name)){
file_put_contents($path.$file_name,'');;
}
$writer->save($path.$file_name);
return ['code'=>0,'url'=>trim($path.$file_name,'.')];
}catch (\Exception $e){
return ['code'=>1,'msg'=>$e->getMessage()];
}
}
/**
* 圖片緩存到本地
* @param $url string 遠程圖片地址
* @param $dir string 本地緩存目錄
* @param $i int 圖片序號
* @return mixed
*/
public static function img_resource($url,$dir,$i){
$data = file_get_contents($url);
$path = $dir.time().'-'.$i;
file_put_contents($path, $data);
return $path;
}
}
```
效果:


- Golang
- Beego框架
- Gin框架
- gin框架介紹
- 使用Gin web框架的知名開源線上項目
- go-admin-gin
- air 熱啟動
- 完整的form表單參數驗證語法
- Go 語言入門練手項目推薦
- Golang是基于多線程模型
- golang 一些概念
- Golang程序開發注意事項
- fatal error: all goroutines are asleep - deadlock
- defer
- Golang 的內建調試器
- go部署
- golang指針重要性
- 包(golang)
- Golang框架選型比較: goframe, beego, iris和gin
- GoFrame
- golang-admin-項目
- go module的使用方法及原理
- go-admin支持多框架的后臺系統(go-admin.cn)
- docker gocv
- go-fac
- MSYS2
- 企業開發框架系統推薦
- gorm
- go-zero
- 優秀系統
- GinSkeleton(gin web 及gin 知識)
- 一次 request -> response 的生命周期概述
- 路由與路由組以及gin源碼學習
- 中間件以及gin源碼學習
- golang項目部署
- 獨立部署golang
- 代理部署golang
- 容器部署golang
- golang交叉編譯
- goravel
- kardianos+gin 項目作為windows服務運行
- go env
- 適用在Windows、Linux和macOS環境下打包Go應用程序的詳細步驟和命令
- Redis
- Dochub
- Docker部署開發go環境
- Docker部署運行go環境
- dochub說明
- Vue
- i18n
- vue3
- vue3基本知識
- element-plus 表格單選
- vue3后臺模板
- Thinkphp
- Casbin權限控制中間件
- 容器、依賴注入、門面、事件、中間件
- tp6問答
- 偽靜態
- thinkphp-queue
- think-throttle
- thinkphp隊列queue的一些使用說明,queue:work和queue:listen的區別
- ThinkPHP6之模型事件的觸發條件
- thinkphp-swoole
- save、update、insert 的區別
- Socket
- workerman
- 介紹
- 從ThinkPHP6移植到Webman的一些技術和經驗(干貨)
- swoole
- swoole介紹
- hyperf
- hf官網
- Swoft
- swoft官網
- easyswoole
- easyswoole官網地址
- EASYSWOOLE 聊天室DEMO
- socket問答
- MySQL
- 聚簇索引與非聚簇索引
- Mysql使用max獲取最大值細節
- 主從復制
- 隨機生成20萬User表的數據
- MySQL進階-----前綴索引、單例與聯合索引
- PHP
- 面向切面編程AOP
- php是單線程的一定程度上也可以看成是“多線程”
- PHP 線程,進程、并發、并行 的理解
- excel數據畫表格圖片
- php第三方包
- monolog/monolog
- league/glide
- 博客-知識網站
- php 常用bc函數
- PHP知識點的應用場景
- AOP(面向切面編程)
- 注解
- 依賴注入
- 事件機制
- phpspreadsheet導出數據和圖片到excel
- Hyperf
- mineAdmin
- 微服務
- nacos注冊服務
- simps-mqtt連接客戶端simps
- Linux
- 切換php版本
- Vim
- Laravel
- RabbitMQ
- thinkphp+rabbitmq
- 博客
- Webman框架
- 框架注意問題
- 關于內存泄漏
- 移動端自動化
- 懶人精靈
- 工具應用
- render
- gitlab Sourcetree
- ssh-agent失敗 錯誤代碼-1
- 資源網站
- Git
- wkhtmltopdf
- MSYS2 介紹
- powershell curl 使用教程
- NSSM(windows服務工具)
- MinGW64
- 知識擴展
- 對象存儲系統
- minio
- 雪花ID
- 請求body參數類型
- GraphQL
- js 深拷貝
- window 共享 centos文件夾
- 前端get/post 請求 特殊符號 “+”傳參數問題
- 什么是SCM系統?SCM系統與ERP系統有什么區別?
- nginx 日志格式統一為 json
- 特殊符號怎么打
- 收藏網址
- 收藏-golang
- 收藏-vue3
- 收藏-php
- 收藏-node
- 收藏-前端
- 規劃ITEM
- 旅游類
- 人臉識別
- dlib
- Docker&&部署
- Docker-compose
- Docker的網絡模式
- rancher
- DHorse
- Elasticsearch
- es與kibana都docke連接
- 4種數據同步到Elasticsearch方案
- GPT
- 推薦系統
- fastposter海報生成
- elasticsearch+logstash+kibana
- beego文檔系統-MinDoc
- jeecg開源平臺
- Java
- 打包部署
- spring boot
- 依賴
- Maven 相關 命令
- Gradle 相關命令
- mybatis
- mybatis.plus
- spring boot 模板引擎
- SpringBoot+Maven多模塊項目(創建、依賴、打包可執行jar包部署測試)完整流程
- Spring Cloud
- Sentinel
- nacos
- Apollo
- java推薦項目
- gradle
- Maven
- Nexus倉庫管理器
- Python
- Masonite框架
- scrapy
- Python2的pip2
- Python3 安裝 pip3
- 安全攻防
- 運維技術
- 騰訊云安全加固建議
- 免費freessl證書申請
- ruby
- homeland
- Protobuf
- GIT
- FFMPEG
- 命令說明
- 音頻
- ffmpeg合并多個MP4視頻
- NODEJS
- 開發npm包
- MongoDB
- php-docker-mongodb環境搭建
- mongo基本命令
- Docker安裝MongoDB最新版并連接
- 少兒編程官網
- UI推薦
- MQTT
- PHP連接mqtt
- EMQX服務端
- php搭建mqtt服務端