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;}}

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

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

相关文章

Android Binder技术概览

Android中的Binder是一种基于远程过程调用(Remote Procedure Call, RPC)的轻量级通信机制,核心用于 Android 系统中的进程间通信(Inter-Process Communication, IPC)。Binder 是 Android 系统中不可或缺的一部分&#…

AI模型---安装cuda与cuDNN

1.安装cuda 先打开cmd 输入nvidia-smi 查看显卡支持cuda对应的版本: 然后去英伟达官网下载cuda(外网多刷几次) https://developer.nvidia.com/cuda-toolkit-archive 注意对应版本 安装过程中如果显示如下图: 请安装visual Stu…

ajax (一)

什么是 AJAX [ˈeɪdʒks] ? 概念:AJAX是浏览器与服务器进行 数据通信 的技术,动态数据交互 怎么用AJAX? 1. 先使用 axios [k‘sio ʊ s] 库, 与服务器进行 数据通信 ⚫ 基于 XMLHttpRequest 封装、代码简单、月下载量在 1…

Load-Balanced-Online-OJ(负载均衡式在线OJ)

负载均衡式在线OJ 前言1. 项目介绍2. 所用技术与环境所用技术栈开发环境 3. 项目宏观结构3.1 项目核心模块3.2 项目的宏观结构 4. comm公共模块4.1 日志(log.hpp )4.1.1 日志主要内容4.1.2 日志使用方式4.1.2 日志代码 4.2 工具(util.hpp&…

微信小程序上传微信官方审核流程(1)

1,打开微信开发者工具 2,微信开发者工具右上角有一个上传按钮,点击上传按钮 3,点击完上传按钮会弹出一个上传成功的提示,点击提示框中的确定按钮 4,点击完确定按钮后会显示填写版本好和项目备注 5&#x…

数据结构(Java版)第一期:时间复杂度和空间复杂度

目录 一、数据结构的概念 1.1. 什么是数据结构 1.2. 算法与数据结构的关系 二、算法效率 三、时间复杂度 3.1. 大O的渐进表⽰法 3.2. 计算冒泡排序的时间复杂度 3.3. 计算二分查找的时间复杂度 四、空间复杂度 4.1. 空间复杂度 4.2. 冒泡排序的空间复杂度 4.3.…

微信小程序全局配置:导航栏、下拉刷新与上拉触底设置教程

微信小程序全局配置:导航栏、下拉刷新与上拉触底设置教程 引言 微信小程序作为一种新兴的轻量级应用,凭借其便捷性和丰富的功能受到了广泛的欢迎。在开发小程序的过程中,合理配置全局属性是提升用户体验的关键。本文将深入探讨小程序的全局配置中的window选项,重点介绍导…

语言模型中的多模态链式推理

神经网络的公式推导 简介摘要引言多模态思维链推理的挑战多模态CoT框架多模态CoT模型架构细节编码模块融合模块解码模块 实验结果运行代码补充细节安装包下载Flan-T5数据集准备rougenltkall-MiniLM-L6-v2运行 简介 本文主要对2023一篇论文《Multimodal Chain-of-Thought Reason…

LLaMA-Mesh: Unifying 3D Mesh Generation with Language Models 论文解读

目录 一、概述 二、相关工作 1、LLMs到多模态 2、3D对象生成 3、自回归的Mesh生成 三、LLaMA-Mesh 1、3D表示 2、预训练模型 3、有监督的微调数据集 4、数据集演示 四、实验 1、生成的多样性 2、不同模型text-to-Mesh的比较 3、通用语境的评估 一、概述 该论文首…

【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的读写锁源…

.NET9 - 新功能体验(二)

书接上回,我们继续来聊聊.NET9和C#13带来的新变化。 01、新的泛型约束 allows ref struct 这是在 C# 13 中,引入的一项新的泛型约束功能,允许对泛型类型参数应用 ref struct 约束。 可能这样说不够直观,简单来说就是Span、ReadO…

抗癌药物“曲妥珠单抗”,或将纳入2025版《中国药典》!

在抗癌药物的浩瀚星空中,曲妥珠单抗如同一颗璀璨的星辰,以其卓越的治疗效果和广泛的应用前景,照亮了无数HER2阳性癌症患者的生命之路。近日,从国家药典委员会传来振奋人心的消息——注射用曲妥珠单抗正式进入《中国药典》2025版国…

JavaParser 的全面介绍

JavaParser 是什么? JavaParser 的快速介绍可以参考: # JavaParser的快速介绍 JavaParser是一个用于解析Java源码的开源工具,它提供了一种简单而有效的方式来解析和操作Java代码。JavaParser解析源码的方式主要基于其将Java代码转换为抽象语…

图形化界面MySQL(MySQL)(超级详细)

1.官网地址 MySQL :: Download MySQL Workbench 1.1在Linux直接点击NO thanks..... 下载完后是这个页面 1.2任何远端登录,再把jj数据库给授权 1.3建立新用户 进行连接 点击这个就运行了 只执行show tables;要先选中 圆圈处支持自己输入 点击这个就执…

【夹板涨停战法】技术形态,原理和操盘技术图文教程

夹板涨停战法的基本形态和原理 夹板涨停是指两股强大的做多力量以夹击的方式紧紧的封夹空头,把空头力量打趴下,让空头的做空希望被破灭。 两股强大的多头力量对付空头,多头战胜,轻易灭掉空头,一切在强大做多力量的把…

【2024 Optimal Control 16-745】Julia语法

Lecture 2 θ和它的导数符号是通过 Julia 中的变量命名方式实现的 变量 θ 的输入: 在 Julia 中,θ 是一个合法的变量名,就像普通的字母 x 或 y 一样。要输入 θ,可以使用以下方法: 在 Jupyter Notebook 或 Julia REP…

Java项目实战II基于SPringBoot的玩具销售商城管理系统(开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、核心代码 五、源码获取 全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 随着儿童娱乐与教育需求的…

Linux系统使用valgrind分析C++程序内存资源使用情况

内存占用是我们开发的时候需要重点关注的一个问题,我们可以人工根据代码推理出一个消耗内存较大的函数,也可以推理出大概会消耗多少内存,但是这种方法不仅麻烦,而且得到的只是推理的数据,而不是实际的数据。 我们可以…

stm32如何接收舵机的控制信号(而不是控制舵机)

看到很多如何stm32用pwm信号控制舵机的文章,老生常谈了 我来写一个stm32接收pwm信号的例子 ,这个pwm信号是用来控制舵机的 背景: 我需要接收航模接收机的,用来控制舵机的pwm信号, 得到这个信号后,做其他事情. 初版代码 pwm.h#ifndef _pwm_H #define _pwm_H#include "s…

RK3588 HDMI2.1电路参考设计原理

RK3588是瑞芯微电子(Rockchip)旗下的一款高性能应用处理器芯片,采用了ARM的big.LITTLE架构,结合了四个高性能的Cortex-A76核心和四个高效能的Cortex-A55核心。 big.LITTLE技术通过结合高性能的“大核”(big cores&…