PHP导出EXCEL含合计行,设置单元格格式
PHP导出EXCEL含合计行,设置单元格格式,水平居中 垂直居中
public function exportSalary(Request $request){//水平居中 垂直居中$styleArray = ['alignment' => ['horizontal' => Alignment::HORIZONTAL_CENTER,'vertical' => Alignment::VERTICAL_CENTER],];//细边框$styleArray1 = ['borders' => ['allBorders' => ['borderStyle' => Border::BORDER_THIN]]];//右对齐 垂直居中$styleArray2 = ['alignment' => ['horizontal' => Alignment::HORIZONTAL_RIGHT,'vertical' => Alignment::VERTICAL_CENTER],];$ym = $request->get('ym');$start_date = $ym . '-01 00:00:00';$month = date("Y年m月", strtotime($start_date));$paper_type = $request->paper_type;$type_id = isset($paper_type)?$paper_type:1;$flag = $type_id==2?'打样':'板房';$yyyymm = date('Y-m', strtotime($start_date));$data = $this->get_salary_data($yyyymm,$type_id);if($data){$name ='XXXX有限公司 (技术部)';$filename = $flag.'计件工资汇总表'.$ym;$title = $flag.'计件工资汇总表';$spreadsheet = new Spreadsheet();$sheet = $spreadsheet->getActiveSheet();$sheet->setTitle($title);$sheet->getColumnDimension('A')->setWidth(6);$sheet->getColumnDimension('B')->setWidth(8);$sheet->getColumnDimension('C')->setWidth(10);$sheet->getColumnDimension('D')->setWidth(10);$sheet->getColumnDimension('E')->setWidth(10);$sheet->getColumnDimension('F')->setWidth(10);$sheet->getColumnDimension('G')->setWidth(10);$sheet->getColumnDimension('H')->setWidth(10);$sheet->getColumnDimension('I')->setWidth(10);$sheet->getColumnDimension('J')->setWidth(10);$sheet->getColumnDimension('K')->setWidth(10);$sheet->getColumnDimension('L')->setWidth(10);$sheet->getColumnDimension('M')->setWidth(10);$sheet->getColumnDimension('N')->setWidth(10);$sheet->getColumnDimension('O')->setWidth(10);$sheet->getColumnDimension('P')->setWidth(15);//第一行$sheet->setCellValue('A1', $name);$sheet->mergeCells('A1:P1');$sheet->getStyle('A1:P1')->getFont()->setBold(true)->setName('Arial')->setSize(20);//第二行$sheet->setCellValue('A2', $month);$sheet->mergeCells('A2:B2');$sheet->setCellValue('C2', $title);$sheet->mergeCells('C2:P2');$sheet->getStyle('C2:P2')->getFont()->setBold(true)->setName('Arial')->setSize(18);$sheet->getStyle('A1:P2')->applyFromArray($styleArray);//第三行$sheet->setCellValue('A3', '序号');$sheet->mergeCells('A3:A4');$sheet->setCellValue('B3', '姓名');$sheet->mergeCells('B3:B4');$sheet->setCellValue('C3', '工资基数');$sheet->mergeCells('C3:F3');$sheet->setCellValue('G3', '薪资结算明细');$sheet->mergeCells('G3:L3');$sheet->setCellValue('M3', '出勤管理');$sheet->mergeCells('M3:N3');$sheet->setCellValue('O3', '发放合计');$sheet->mergeCells('O3:O4');$sheet->setCellValue('P3', '备注');$sheet->mergeCells('P3:P4');//第四行$sheet->setCellValue('C4', '底薪');$sheet->setCellValue('D4', '产量考核');$sheet->setCellValue('E4', '绩效考核');$sheet->setCellValue('F4', '综合收入');$sheet->setCellValue('G4', '及时率');$sheet->setCellValue('H4', '产量薪资');$sheet->setCellValue('I4', '绩效得分');$sheet->setCellValue('J4', '绩效薪资');$sheet->setCellValue('K4', '超产奖励');$sheet->setCellValue('L4', '点工');$sheet->setCellValue('M4', '出勤天数');$sheet->setCellValue('N4', '请假天数');$sheet->getStyle('G4')->getAlignment()->setWrapText(true);$sheet->getStyle('I4')->getAlignment()->setWrapText(true);$sheet->getRowDimension('1')->setRowHeight(28);$sheet->getRowDimension('2')->setRowHeight(25);$sheet->getRowDimension('3')->setRowHeight(23);$sheet->getRowDimension('4')->setRowHeight(30);//开始装数据$count = 5;foreach ($data as $key =>$value){$xh = $key + 1;$sheet->setCellValue('A'.$count, $xh);$sheet->setCellValue('B'.$count, $value['name']);//姓名$sheet->setCellValue('C'.$count, $value['basic_salary']);//底薪$sheet->setCellValue('D'.$count, $value['yield_basic_salary']);//产量考核$sheet->setCellValue('E'.$count, $value['merit_basic_salary']);//绩效考核$sheet->setCellValue('F'.$count, $value['all_basic_salary']);//综合收入$sheet->setCellValue('G'.$count, $value['timely_rate']/100); //及时率$sheet->setCellValue('H'.$count, $value['yield_salary']);//产量薪资$sheet->setCellValue('I'.$count, $value['merit_score']);//绩效得分$sheet->setCellValue('J'.$count, $value['merit_salary']); //绩效薪资$sheet->setCellValue('K'.$count, $value['over_salary']); //超产奖励$sheet->setCellValue('L'.$count, $value['timing_cut_salary']); //点工扣款$sheet->setCellValue('M'.$count, ""); //出勤天数$sheet->setCellValue('N'.$count, ""); //请假天数$sheet->setCellValue('O'.$count, $value['all_salary']); //发放合计$sheet->setCellValue('P'.$count, $value['remark']); //备注$sheet->getRowDimension($count)->setRowHeight(25);$count++;}$sheet->getStyle('A3:P'.($count))->applyFromArray($styleArray1)->applyFromArray($styleArray); //画上几线$sheet->getStyle('C5:O'.($count))->getNumberFormat()->setFormatCode("0.00");//保留小数2位$sheet->getStyle('A1:P2')->applyFromArray($styleArray);$sheet->getStyle('C5:O'.($count))->applyFromArray($styleArray2);//右对齐 垂直居中$sheet->getStyle('J5:O'.($count))->applyFromArray($styleArray2);//右对齐 垂直居中$sheet->getStyle('A3:P4')->getFont()->setBold(true);//合计行$sheet->setCellValue('A'.$count,'合计');$sheet->mergeCells('A'.$count.':B'.$count);$sheet->setCellValue('C'.$count,'=SUM(C5:C'.($count-1).')');$sheet->setCellValue('D'.$count,'=SUM(D5:D'.($count-1).')');$sheet->setCellValue('E'.$count,'=SUM(E5:E'.($count-1).')');$sheet->setCellValue('F'.$count,'=SUM(F5:F'.($count-1).')');$sheet->setCellValue('G'.$count,'=AVERAGE(G5:G'.($count-1).')');$sheet->setCellValue('H'.$count,'=SUM(H5:H'.($count-1).')');$sheet->setCellValue('I'.$count,'=AVERAGE(I5:I'.($count-1).')');$sheet->setCellValue('J'.$count,'=SUM(J5:J'.($count-1).')');$sheet->setCellValue('K'.$count,'=SUM(K5:K'.($count-1).')');$sheet->setCellValue('L'.$count,'=SUM(L5:L'.($count-1).')');$sheet->setCellValue('O'.$count,'=SUM(O5:O'.($count-1).')');//设置G列单元格格式为百分比0.00%$sheet->getStyle('G5:G'.$count)->getNumberFormat()->setFormatCode(\PHPExcel_Style_NumberFormat::FORMAT_PERCENTAGE_00);//最后一行$last_count = $count + 1;$sheet->setCellValue('A'.$last_count, '审批:');$sheet->mergeCells('A'.$last_count.':F'.$last_count);$sheet->setCellValue('G'.$last_count, '审核:');$sheet->mergeCells('G'.$last_count.':K'.$last_count);$sheet->setCellValue('L'.$last_count, '制表:');$sheet->mergeCells('L'.$last_count.':P'.$last_count);header('Content-Type:application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');header('Content-Disposition: attachment;filename="'.$filename.'.xlsx"');header('Cache-Control: max-age=0');ob_end_clean();$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');$writer->save('php://output');exit;}}
相关文章:
PHP导出EXCEL含合计行,设置单元格格式
PHP导出EXCEL含合计行,设置单元格格式,水平居中 垂直居中 public function exportSalary(Request $request){//水平居中 垂直居中$styleArray [alignment > [horizontal > Alignment::HORIZONTAL_CENTER,vertical > Alignment::VERTICAL_CE…...
RabbitMQ 之 死信队列
一、死信的概念 先从概念解释上搞清楚这个定义,死信,顾名思义就是无法被消费的消息,字面意思可以这样理 解,一般来说,producer 将消息投递到 broker 或者直接到 queue 里了,consumer 从 queue 取出消息进行…...
【创建型设计模式】单例模式
【创建型设计模式】单例模式 这篇博客接下来几篇都将阐述设计模式相关内容。 接下来的顺序大概是:单例模式、工厂方法模式、抽象工厂模式、建造者模式、原型模式。 一、什么是单例模式 单例模式是一种创建型设计模式,它保证一个类仅有一个实例&#…...
Charles抓包工具-笔记
摘要 概念: Charles是一款基于 HTTP 协议的代理服务器,通过成为电脑或者浏览器的代理,然后截取请求和请求结果来达到分析抓包的目的。 功能: Charles 是一个功能全面的抓包工具,适用于各种网络调试和优化场景。 它…...
Go语言使用 kafka-go 消费 Kafka 消息教程
Go语言使用 kafka-go 消费 Kafka 消息教程 在这篇教程中,我们将介绍如何使用 kafka-go 库来消费 Kafka 消息,并重点讲解 FetchMessage 和 ReadMessage 的区别,以及它们各自适用的场景。通过这篇教程,你将了解如何有效地使用 kafk…...
【论文笔记】Number it: Temporal Grounding Videos like Flipping Manga
🍎个人主页:小嗷犬的个人主页 🍊个人网站:小嗷犬的技术小站 🥭个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。 基本信息 标题: Number it: Temporal Grou…...
C语言菜鸟入门·关键字·int的用法
目录 1. int关键字 1.1 取值范围 1.2 符号类型 1.3 运算 1.3.1 加法运算() 1.3.2 减法运算(-) 1.3.3 乘法运算(*) 1.3.4 除法运算(/) 1.3.5 取余运算(%) 1.3.6 自增()与自减(--) 1.3.7 位运算 2. 更多关键字 1. int关键字 int 是一个关键字࿰…...
基于企业微信客户端设计一个文件下载与预览系统
在企业内部沟通与协作中,文件分享和管理是不可或缺的一部分。企业微信(WeCom)作为一款广泛应用于企业的沟通工具,提供了丰富的API接口和功能,帮助企业进行高效的团队协作。然而,随着文件交换和协作的日益增…...
昇思MindSpore第七课---文本解码原理
1. 文本解码原理 文本解码是将模型的输出(通常是概率分布或词汇索引)转换为可读的自然语言文本的过程。在生成文本时,常见的解码方法包括贪心解码、束搜索(BeamSearch)、随机采样等。 2 实践 2.1 配置环境 安装mindn…...
C# 数据结构之【图】C#图
1. 图的概念 图是一种重要的数据结构,用于表示节点(顶点)之间的关系。图由一组顶点和连接这些顶点的边组成。图可以是有向的(边有方向)或无向的(边没有方向),可以是加权的ÿ…...
传输控制协议(TCP)和用户数据报协议(UDP)
一、传输控制协议(TCP) 传输控制协议(Transmission Control Protocol,TCP)是一种面向连接的、可靠的、基于字节流的传输层通信协议,由 IETF 的 RFC 793 定义。 它通过三次握手建立连接,确保数…...
【Python爬虫】Scrapy框架实战---百度首页热榜新闻
如何利用Scrapy框架实战提取百度首页热榜新闻的排名、标题和链接 一、安装Scrapy库 二、创建项目(以BaiduSpider为例) scrapy startproject BaiduSpider生成每个文件的功能: 二、 创建爬虫脚本(爬虫名:newsÿ…...
采用python3.12 +django5.1 结合 RabbitMQ 和发送邮件功能,实现一个简单的告警系统 前后端分离 vue-element
一、开发环境搭建和配置 #mac环境 brew install python3.12 python3.12 --version python3.12 -m pip install --upgrade pip python3.12 -m pip install Django5.1 python3.12 -m django --version #用于检索系统信息和进程管理 python3.12 -m pip install psutil #集成 pika…...
Qt 实现网络数据报文大小端数据的收发
1.大小端数据简介 大小端(Endianness)是计算机体系结构的一个术语,它描述了多字节数据在内存中的存储顺序。以下是大小端的定义和它们的特点: 大端(Big-Endian) 在大端模式中,一个字的最高有效…...
[译]Elasticsearch Sequence ID实现思路及用途
原文地址:https://www.elastic.co/blog/elasticsearch-sequence-ids-6-0 如果 几年前,在Elastic,我们问自己一个"如果"问题,我们知道这将带来有趣的见解: "如果我们在Elasticsearch中对索引操作进行全面排序会怎样…...
Java基于SpringBoot+Vue的藏区特产销售平台
博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…...
12-表的约束
知识背景 表的约束,就是在表中的数据上加上约束,也被称为数据完整性约束。数据完整性约束的目的是为了不被规定的、不符合规范的数据进入数据库 在录入数据库或数据发生变化时,DBMS(数据库管理系统)会按照一定的约束条件对数据进行监测&…...
【人工智能】深度学习入门:用TensorFlow实现多层感知器(MLP)模型
《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 多层感知器(MLP)是一种基础的神经网络结构,广泛应用于分类和回归任务。作为深度学习的重要组成部分,理解并实现MLP是学习更复杂神经网络模型的基础。本文将介绍多层感知器的核心概念、数学原理,并使用…...
【Go】-go中的锁机制
目录 一、锁的基础知识 1. 互斥量/互斥锁 2. CAS(compare and swap) 3. 自旋锁 4. 读写锁 5. 乐观锁 & 悲观锁 6. 死锁 二、go中锁机制 1. Mutex-互斥锁 2. RWMutex-读写锁 2.1 RWMutex流程概览 2.2 写锁饥饿问题 2.3. golang的读写锁源…...
c ++零基础可视化——vector
c 零基础可视化——vector 初始化 vector<int> v0(5); // 0 0 0 0 0 vector<int> v1(5, 1); // 1 1 1 1 1 vector<int> v2{1, 2, 3} // 1 2 3 vector<int> v3(v1); // 1 1 1 1 1 vector<vector<int>> v4(2, vect…...
SciencePlots——绘制论文中的图片
文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了:一行…...
React第五十七节 Router中RouterProvider使用详解及注意事项
前言 在 React Router v6.4 中,RouterProvider 是一个核心组件,用于提供基于数据路由(data routers)的新型路由方案。 它替代了传统的 <BrowserRouter>,支持更强大的数据加载和操作功能(如 loader 和…...
Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例
使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件,常用于在两个集合之间进行数据转移,如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model:绑定右侧列表的值&…...
Nuxt.js 中的路由配置详解
Nuxt.js 通过其内置的路由系统简化了应用的路由配置,使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...
04-初识css
一、css样式引入 1.1.内部样式 <div style"width: 100px;"></div>1.2.外部样式 1.2.1.外部样式1 <style>.aa {width: 100px;} </style> <div class"aa"></div>1.2.2.外部样式2 <!-- rel内表面引入的是style样…...
【HTTP三个基础问题】
面试官您好!HTTP是超文本传输协议,是互联网上客户端和服务器之间传输超文本数据(比如文字、图片、音频、视频等)的核心协议,当前互联网应用最广泛的版本是HTTP1.1,它基于经典的C/S模型,也就是客…...
聊一聊接口测试的意义有哪些?
目录 一、隔离性 & 早期测试 二、保障系统集成质量 三、验证业务逻辑的核心层 四、提升测试效率与覆盖度 五、系统稳定性的守护者 六、驱动团队协作与契约管理 七、性能与扩展性的前置评估 八、持续交付的核心支撑 接口测试的意义可以从四个维度展开,首…...
2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...
排序算法总结(C++)
目录 一、稳定性二、排序算法选择、冒泡、插入排序归并排序随机快速排序堆排序基数排序计数排序 三、总结 一、稳定性 排序算法的稳定性是指:同样大小的样本 **(同样大小的数据)**在排序之后不会改变原始的相对次序。 稳定性对基础类型对象…...
【JVM】Java虚拟机(二)——垃圾回收
目录 一、如何判断对象可以回收 (一)引用计数法 (二)可达性分析算法 二、垃圾回收算法 (一)标记清除 (二)标记整理 (三)复制 (四ÿ…...
