Laravel 使用Excel导出的文件中,指定列数据格式为日期,方便后期的数据筛选操作

  • 背景

    最近,后台运营人员要求导出的 Excel 文件,
    要求能够满足对于 [下单日期] 的筛选操作,即满足在年份、月份上的选择

    通过了解,发现:
    先前导出的文件,默认列数据都是字符串(文本)格式,需对指定的列变更为日期格式
    同时,参考了网上的众多经验都多多少少难以实现
    其次因为 Laravel-excel 控件版本的问题,要实现的方式也不同
    在此,根据控件版本的不同,进行步骤整理,以便能帮助到有需要的小伙伴 …

  • 所要达成的目标
    在这里插入图片描述

  • 框架

Laravel 版本:	Laravel5.8
Excel   版本:	[maatwebsite/excel v2.1.*]  [maatwebsite/excel 3.1]

实现步骤

首先,确保你已经安装了 Laravel-Excel 包,可以通过 Composer 安装

  • composer 安装指令如下:
# 默认最新版本安装指令
composer require maatwebsite/excel# 如果指定版本,需知道版本号
composer require maatwebsite/excel:<version>

①. laravel-excel2.1 版本下实现方式

  • 参考技术文档:Laravel Excel2.1 - Column formatting

参考文章:laravel-excel 导出的时候写入的日期格式数据怎么在excel中正确显示成可以筛选的日期格式数据

  • 提示
1. 根据实际操作,发现,对于下单日期的写入,需计算从 1900-01-01到目标日期的天数
2. 但是,还需多添加两天(容错处理,验证所得,可百度解释)
3. 并且,无需手动 在天数后面拼接一个"\t"
  • 调用参考
//指定下单日期,需要计算从 1900-01-01到目标日期的天数
...
//举例
$order_create_date = '2024-07-23';
$excelListData['下单日期'] = get_days_since1900($order_create_date);
$this->saveExcel($title, $excelListData,'订单列表',['W' => 'yyyy-mm-dd']);
  • 整理 保存 Excel 文件方法 saveExcel()get_days_since1900()
    /*** @notes:保存 Excel文件* @param string $title     标题* @param array $cellData   数据* @param string $sheetName 工作表名* @param array $columnFormat 列格式* @Time: 2024/8/6 9:38*/public function saveExcel($title = 'title', $cellData = [], $sheetName = 'sheet1',$columnFormat = []){Excel::create($title, function ($excel) use ($cellData, $sheetName,$columnFormat) {$excel->sheet($sheetName, function ($sheet) use ($cellData,$columnFormat) {if ($columnFormat){//设置列格式$sheet->setColumnFormat($columnFormat);}$sheet->rows($cellData);});})->store('xlsx'); // 文件默认保存到storage/exports目录下}/*** @notes:获取 从1900-01-01的天数* @param string $curr_date 目标日期* @return false|int  测试发现,计算所得的天数需加2,才能满足当前应用* @throws Exception* @author: zhanghj* @Time: 2024/8/6 10:10*/
function get_days_since1900($curr_date = '') {$date = new \DateTime($curr_date);$date1900 = new \DateTime('1900-01-01');$interval = $date1900->diff($date)->days;return intval($interval+2);
}

②. laravel-excel3.1 版本下实现方式

  • 参考技术文档:Laravel Excel3.0 Formatting columns

  • 创建导出类 UserExport.php

<?php
namespace App\Http\Model;use Maatwebsite\Excel\Concerns\Exportable;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
use Maatwebsite\Excel\Concerns\WithHeadings;
use Maatwebsite\Excel\Concerns\WithMapping;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
use PhpOffice\PhpSpreadsheet\Shared\Date;/*** Excel 导出类* Class UserExport* @package App\Http\Model*/
class UserExport implements FromCollection,WithMapping,WithHeadings,WithColumnFormatting
{use Exportable;public function collection(){return (new User())->getExportData();}public function map($row): array{$dateTime = new \DateTime($row->reg_date);// 数据映射逻辑return [$row->id,$row->nick_name,Date::dateTimeToExcel($dateTime),// 确保这里是日期格式$row->auth_tel,// ...其他数据映射];}public function headings(): array{// 表头return ['ID','昵称','注册日期','手机号码'// ...其他表头];}public function columnFormats(): array{// 设置日期格式的筛选return ['C' => NumberFormat::FORMAT_DATE_YYYYMMDD,// ...其他格式];}
}
  • 参考,绑定的数据源获取方法
    /*** @notes:获取导出的数据* @return array 注意返回的数据为 Collection 集合形式* @author: zhanghj* @Time: 2024/8/6 17:14*/public function getExportData(){$list = $this->select('id','nick_name','reg_time','auth_tel')->limit(7)->get();foreach ($list as $key => $value){$dateString = date("Y-m-d",$value['reg_time']??0);$list[$key]['reg_date'] = $dateString;}return $list??[];}
  • controller 调用方法,参考如下:
class TestController extends Controller
{public function index(){$filePath = 'exports/users_'.time().'.xlsx';//将文件存储到目录 “storage\app\exports” 下$export = Excel::store(new UserExport(2018),$filePath);//return Excel::download(new UserExport,$filePath); //如果直接浏览器下载文件,需注意路径不能有 /return 'Test - MT';}
}
  • 导出文件,参考截图如下:

附录

  • 参考文章
    • laravel-excel导出的时候写入的日期格式数据怎么在excel中正确显示成可以筛选的日期格式数据
    • Laravel Excel 3.1 导出表格详解(自定义sheet,合并单元格,设置样式,格式化列数据)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/396595.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

bia文件中码偏差对实时PPP解算分析

1. 码偏差对定位影响 码偏差对未知收敛时间有影响&#xff0c;对最终精度影响不大&#xff08;权比1000:1&#xff09;

前端工程化14-git merge 以及 git rebase。

rebase会把当前分支的 commit 放到公共分支的最后面,所以叫变基。就好像从公共分支又重新拉出来这个分支一样。 举例&#xff1a; 如果从 master 拉个feature分支出来,然后提交了几个 commit,这个时候刚好有人把他开发的东西合并到 master 了,这个时候 master 就比你拉分支的…

【Hot100】LeetCode—295. 数据流的中位数

目录 1- 思路① 添加元素实现② 计算实现 2- 实现⭐295. 数据流的中位数——题解思路 原题链接&#xff1a;295. 数据流的中位数 1- 思路 利用优先级队列实现一个大顶堆和一个小顶堆大顶堆用来存放较小的元素&#xff0c;小顶堆用来存放较大的元素 ① 添加元素实现 如果当前…

JVM知识总结(双亲委派机制)

文章收录在网站&#xff1a;http://hardyfish.top/ 文章收录在网站&#xff1a;http://hardyfish.top/ 文章收录在网站&#xff1a;http://hardyfish.top/ 文章收录在网站&#xff1a;http://hardyfish.top/ 双亲委派机制 双亲委派类加载过程 当App尝试加载一个类时&#x…

haproxy基础

HAProxy (High Availability Proxy) 是一款强大的开源负载均衡器和代理服务器。它主要用于提高 Web 应用程序和服务的可用性和性能。HAProxy 可以在 TCP 和 HTTP 层面上工作&#xff0c;并且支持多种负载均衡算法&#xff0c;广泛应用于高流量网站和大型分布式系统中。 社区版…

【数学建模】简单的优化模型-6 血管分支

背景&#xff1a;机体提供能量维持血液在血管中的流动&#xff0c;给血管壁以营养&#xff1b;克服血液流动的阻力&#xff0c;能量消耗与血管的几何形状有关。在长期进化中动物血管的几何形状已经在能量消耗最小原则下达到最优化。 问题&#xff1a;在能量消耗最小原则下&…

现代卷积神经网络

经典的CNN架构 一、早期的CNN架构 LeNet LeNet&#xff0c;&#xff08;也称为LeNet-5&#xff0c;5代表使用了2个卷积层和3个全连接层&#xff09;是一个经典的卷积神经网络架构&#xff0c;最初由Yann LeCun等人开发用于MNIST数据集手写数字&#xff08;灰度图像 输入通道…

nuPlan环境配置和开环及闭环评测

环境配置 下载nuplan mini 数据集 nuPlan Maps nuPlan Mini Split 解压并按照制定目录结构存储 ./nuplan/ |-- maps -- nuplan-v1.1-- splits-- mini为了不修改代码, 需软链目录 ln -s ./nuplan /data/sets/ 下载nuplan镜像 docker pull horizonrobotics/nuplan:cuda11.8.0…

Golang | Leetcode Golang题解之第327题区间和的个数

题目&#xff1a; 题解&#xff1a; func countRangeSum(nums []int, lower, upper int) int {var mergeCount func([]int) intmergeCount func(arr []int) int {n : len(arr)if n < 1 {return 0}n1 : append([]int(nil), arr[:n/2]...)n2 : append([]int(nil), arr[n/2:]…

Flink 实时数仓(八)【DWS 层搭建(二)流量域、用户域、交易域搭建】

前言 今天的任务是完成流量域最后一个需求、用户域的两个需求以及交易域的部分需求&#xff1b; 1、流量域页面浏览各窗口汇总表 任务&#xff1a;从 Kafka 页面日志主题读取数据&#xff0c;统计当日的首页和商品详情页独立访客数。 注意&#xff1a;一般我们谈到访客&…

H264基本原理

文章目录 引子 - 为什么要视频压缩I、 P、 B帧GOP图像序列H264编码介绍其它为什么视频格式一般为YUVH264 画质级别 参考资料 引子 - 为什么要视频压缩 一张为720x480的图像&#xff0c;用YUV420P的格式来表示&#xff0c; 其大小为&#xff1a; 720 * 480 * 1.5 约等于0.5MB。…

【深度学习与NLP】——注意力机制

1 注意力机制 1.1 学习目标 了解什么是注意力计算规则以及常见的计算规则.了解什么是注意力机制及其作用.掌握注意力机制的实现步骤. 什么是注意力: 我们观察事物时&#xff0c;之所以能够快速判断一种事物(当然允许判断是错误的), 是因为我们大脑能够很快把注意力放在事物最具…

使用Python和Flask构建简单的RESTful API

目录 环境准备 创建Flask应用 运行Flask应用 扩展功能&#xff1a;处理POST请求 注意事项 在Web开发中&#xff0c;RESTful API是一种广泛使用的架构风格&#xff0c;它允许客户端和服务器之间通过HTTP请求进行通信。Python的Flask框架以其轻量级和易于上手的特点&#xf…

XML动态sql查询当前时间之前的信息报错

如图&#xff0c;sql语句在数据库里可以正常运行但是再XML文件不可以正常运行&#xff0c;报错。 原因&#xff1a;在XML中小于号"<"是会被默认认定成文一个标签的开始&#xff0c;所以用小于号就会报错。 解决办法&#xff1a; 1.把表达式反过来改成大于号 2…

linux 源码部署polardb-x 错误汇总

前言 在linux 源码部署polardb-x 遇到不少错误&#xff0c;特在此做个汇总。 问题列表 CN 启动报错 Failed to init new TCP 详细错误如下 Caused by: Failed to init new TCP. XClientPool to my_polarx#267b21d8127.0.0.1:33660 now 0 TCP(0 aging), 0 sessions(0 runni…

MySQL的字符集配置

MySQL的字符集配置 创建database创建表插入数据查看字符集配置查看字符集的比较规则关于字符集的配置总结 创建database create database dbtest1; show databases;use dbtest1;创建表 create table employees(id int,name varchar(15));插入数据 insert into employees valu…

PDF转换器推荐:轻松将图片批量转为PDF

高质量的图片与文档管理已经逐渐成为了我们日常工作中不可或缺的一部分。为了防止图片在传输的过程中被压缩&#xff0c;我经常将他们转换为PDF格式。这次我给你推荐几个我常用的图片转PDF的小工具吧。 1.福昕PDF转换大师 链接一下>>https://www.pdf365.cn/pdf2word/ …

牛客JS题(三十二)Proxy计数器

注释很详细&#xff0c;直接上代码 涉及知识点&#xff1a; Proxy的基础使用set、deleteProperty及deleteProperty用法 题干&#xff1a; 我的答案 <!DOCTYPE html> <html><head><meta charsetutf-8></head><body><script type"t…

【C++】类和对象 ——中

1. 赋值运算符重载 1.1 运算符重载 • 当运算符被⽤于类类型的对象时&#xff0c;C语⾔允许我们通过运算符重载的形式指定新的含义。C规定类类型对象使⽤运算符时&#xff0c;必须转换成调⽤对应运算符重载&#xff0c;若没有对应的运算符重载&#xff0c;则会编译报错。 •…

clion开发stm32f4系列(2)————使用rt-thread提供的libc库时遇到的问题

CMakeList文件配置 问题1 解决方式 问题2&#xff08;在链接过程中&#xff0c;出现重复定义&#xff09; 解决 编译结果(解决ok)