COMPOSER安装使用WIN下升级PHP-V

想用TP6使用phpspreadsheet但是说我PHP版本低,原来是PHP7.0  composer要求至少7.4

直接修改环境变量,把PHP目录切换到7.4

composer升级比较简单,在PHP目录下CMD然后官网的命令执行下即可

下面就可以在TP根目录下执行命令安装PHPSPREADSHEET

程序就简单了

use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\IOFactory;$spreadsheet = new Spreadsheet();// 获取活动工作薄$sheet = $spreadsheet->getActiveSheet();// 获取单元格$cellA = $sheet->getCell('A1');// 设置单元格的值$cellA->setValue('姓名');// 设置 A 列 列宽$sheet->getColumnDimension('A')->setWidth(30);// 设置第一行 行高$sheet->getRowDimension(1)->setRowHeight(20);$cellB = $sheet->getCell('B1');$cellB->setValue('手机号');$sheet->getColumnDimension('B')->setWidth(30);$cellC = $sheet->getCell('C1');$cellC->setValue('学历');$sheet->getColumnDimension('C')->setWidth(30);$cellD = $sheet->getCell('D1');$cellD->setValue('考试目的');$sheet->getColumnDimension('D')->setWidth(30);$cellE = $sheet->getCell('E1');$cellE->setValue('考试方式');$sheet->getColumnDimension('E')->setWidth(30);$cellF = $sheet->getCell('F1');$cellF->setValue('报名时间');$sheet->getColumnDimension('F')->setWidth(30);$cellG = $sheet->getCell('G1');$cellG->setValue('来源');$sheet->getColumnDimension('G')->setWidth(30);// 设置样式 标题栏$styleArray = ['alignment' => ['horizontal' => 'center', //水平居中'vertical' => 'center', //垂直居中],'font' => ['name' => '黑体','bold' => false,'size' => 10]];// 设置样式 正文$styleArrayBody = ['alignment' => ['horizontal' => 'center', //水平居中'vertical' => 'center', //垂直居中],'font' => ['name' => '宋体','bold' => false,'size' => 10]];// 应用样式$sheet->getStyle('A1')->applyFromArray($styleArray);$sheet->getStyle('B1')->applyFromArray($styleArray);$sheet->getStyle('C1')->applyFromArray($styleArray);$sheet->getStyle('D1')->applyFromArray($styleArray);$sheet->getStyle('E1')->applyFromArray($styleArray);$sheet->getStyle('F1')->applyFromArray($styleArray);$sheet->getStyle('G1')->applyFromArray($styleArray);// 从 A2 开始填充数据foreach ($data as $k => $v) {if($v['aid'] == 99999){$laiyuan = "专题";}else{$laiyuan = "文章";}$n = $k + 2;// 获取单元格$cellA = $sheet->getCell('A'.$n);// 设置单元格的值$cellA->setValue($v['uname']);$cellB = $sheet->getCell('B'.$n);$cellB->setValue($v['phone']);$cellC = $sheet->getCell('C'.$n);$cellC->setValue($v['xueli']);$cellD = $sheet->getCell('D'.$n);$cellD->setValue($v['mudi']);$cellE = $sheet->getCell('E'.$n);$cellE->setValue($v['fangshi']);$cellF = $sheet->getCell('F'.$n);$cellF->setValue($v['createtime']);$cellG = $sheet->getCell('G'.$n);$cellG->setValue($laiyuan);// 再给表格体设置样式$sheet->getStyle('A'.$n)->applyFromArray($styleArrayBody);$sheet->getStyle('B'.$n)->applyFromArray($styleArrayBody);$sheet->getStyle('C'.$n)->applyFromArray($styleArrayBody);$sheet->getStyle('D'.$n)->applyFromArray($styleArrayBody);$sheet->getStyle('E'.$n)->applyFromArray($styleArrayBody);$sheet->getStyle('F'.$n)->applyFromArray($styleArrayBody);$sheet->getStyle('G'.$n)->applyFromArray($styleArrayBody);}// MIME 协议的扩展$filename = date('Y-m-d').'报名表单.xlsx';header('Content-Type:application/vnd.ms-excel');header('Content-Disposition:attachment;filename='.$filename);header('Cache-Control:max-age=0');$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');$writer->save('php://output');

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

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

相关文章

Docker数据集与自定义镜像:构建高效容器的关键要素

目录 博客前言 一.数据卷 1.数据卷介绍 2.实战 宿主机和容器共享目录 容器和容器之间共享目录 二.自定义镜像 1.自定义镜像介绍 2.实战 2.1自定义centos,具备vim及ifconfig作用 构建镜像 通过镜像运行一个容器进行测试 2.2自定义tomact(文件为…

【IO流系列】字符流练习(拷贝、文件加密、修改文件数据)

字符流练习 练习1:文件夹拷贝1.1 需求1.2 代码实现1.3 输出结果 练习2:文件加密与解密2.1 需求2.2 代码实现2.3 输出结果 练习3:修改文件数据(常规方法)3.1 需求3.2 代码实现3.3 输出结果 练习4:修改文件数…

CSP-201712-2-游戏

CSP-201712-2-游戏 解题思路 初始化变量:定义整数变量n和k,分别用来存储小朋友的总数和淘汰的特定数字。然后定义了num(用来记录当前报的数)和peopleIndex(用来记录当前报数的小朋友的索引)。 初始化小朋…

无法访问云服务器上部署的Docker容器(二)

说明:记录一次使用公网IP 接口地址无法访问阿里云服务接口的问题; 描述 最近,我使用Docker部署了jeecg-boot项目,部署过程都没有问题,也没有错误信息。部署完成后,通过下面的地址访问后端Swagger接口文档…

react useMemo 用法

1,useCallback 的功能完全可以由 useMemo 所取代,如果你想通过使用 useMemo 返回一个记忆函数也是完全可以的。 usecallback(fn,inputs)is equivalent to useMemo(()> fn, inputs). 区别是:useCallback不会执行第一个参数函数,而是将它返…

获取当前数据 上下移动

点击按钮 上下移动 当前数据 代码 // 出国境管理 登记备案人员列表 <template><a-row><a-col span"24"><a-card :class"style[a-table-wrapper]"><!-- 出国境 登记备案人员列表 --><a-table:rowKey"records >…

sql 注入 之sqli-labs/less-6 双注入,双引号报错注入

和第五关类似&#xff0c;只不过闭合符号是双引号 1&#xff0c;查数据库 1"and%20(updatexml(1,concat(0x7e,(select%20database()),0x7e),1))%20-- 2.查表 内容有多行&#xff0c;所以使用limit依次查询 1"and%20(updatexml(1,concat(0x7e,(select%20table_nam…

【Linux系统化学习】线程概念

目录 线程的概念 线程的引出 什么是线程 理解线程比进程更加的轻量化 线程的优点 现成的缺点 线程异常 线程用途 Linux进程VS线程 线程的简单现象 线程的概念 有关操作系统的书籍或者课本都会这样描述线程&#xff1a; 线程是比进程轻量化的一种执行流线程是进程内部…

利用小蜜蜂AI智能问答ChatGPT+AI高清绘图生成图文故事案例

利用小蜜蜂AI智能问答ChatGPTAI高清绘图生成图文故事案例 这段时间利用小蜜蜂AI网站做了一些编程、绘图以及数据分析方面的案例。再过几个月&#xff0c;我的大孙子就要出生了。我要用小蜜蜂AI智能问答和AI高清绘图为大孙子生成一个1-9的数字图文故事。 小蜜蜂AI网站可以扫如…

前端打包部署(黑马学习笔记)

我们的前端工程开发好了&#xff0c;但是我们需要发布&#xff0c;那么如何发布呢&#xff1f;主要分为2步&#xff1a; 1.前端工程打包 2.通过nginx服务器发布前端工程 前端工程打包 接下来我们先来对前端工程进行打包 我们直接通过VS Code的NPM脚本中提供的build按钮来完…

【HTML5】浏览器不能显示字体报错Failed to decode downloaded font问题解决

把网上的项目中字体通过链接保存下来在本地上使用&#xff0c;在本地服务器上运行站点发现&#xff0c;用Chrome浏览器访问的时候&#xff0c;出现错误提示不能正常显示字体&#xff0c;怎么解决呢&#xff0c;看看怎么搞。 文章目录 发现问题提示警告提示错误 字体检查打开文件…

Redisson限流算法

引入依赖 <dependency><groupId>org.redisson</groupId><artifactId>redisson-spring-boot-starter</artifactId><version>3.12.3</version> </dependency>建议版本使用3.15.5以上 使用 这边写了一个demo示例&#xff0c;定…

C++ //练习 10.7 下面的程序是否有错误?如果有,请改正。

C Primer&#xff08;第5版&#xff09; 练习 10.7 练习 10.7 下面的程序是否有错误&#xff1f;如果有&#xff0c;请改正。 (a) vector<int>vec; list<int> lst; int i;while(cin>>i)lst.push_back(i);copy(lst.cbegin(), lst.cend(), vec.begin());(b) …

Unity(第二十二部)官方的反向动力学一般使用商城的IK插件,这个用的不多

反向动力学&#xff08;Inverse Kinematic&#xff0c;简称IK&#xff09;是一种通过子节点带动父节点运动的方法。 正向动力学 在骨骼动画中&#xff0c;大多数动画是通过将骨架中的关节角度旋转到预定值来生成的&#xff0c;子关节的位置根据父关节的旋转而改变&#xff0c;这…

苍穹外卖学习 Day10 Day11 Day12

前言 用于记录苍穹外卖Day10、Day11、Day12的学习 Day10 订单状态定时处理 来电提醒 客户催单 订单状态定时处理 Spring Task Spring Task是一个任务调度工具&#xff0c;可以按照约定的时间自动执行某个代码逻辑&#xff08;定时自动执行某段Java代码&#xff09; cron表…

ElasticSearch之suggester API

写在前面 当我们在使用搜索引擎进行的查询到时候&#xff0c;如果是输入错误的话&#xff0c;搜索引擎会给出一些搜索建议&#xff0c;如下&#xff1a; 在es中也提供了类似的功能&#xff0c;叫做suggester API。 1&#xff1a;原理和种类 原理是将查询的信息分为很多个词…

Python并发编程:多线程-信号量,Event,定时器

一 信号量 信号量也是一把锁&#xff0c;可以指定信号量为5&#xff0c;对比互斥锁同一时间只能有一个任务抢到锁去执行&#xff0c;信号量同一时间可以有5个任务拿到锁去执行&#xff0c;如果说互斥锁是合租房屋的人去抢一个厕所&#xff0c;那么信号量就相当于一群路人争抢公…

基于springboot+vue的在线考试系统(源码+论文)

文章目录 目录 文章目录 前言 一、功能设计 二、功能页面 三、论文 前言 现在我国关于在线考试系统的发展以及专注于对无纸化考试的完善程度普遍不高&#xff0c;关于对考试的模式还大部分还停留在纸介质使用的基础上&#xff0c;这种教学模式已不能解决现在的时代所产生的考试…

前端【技术类】资源学习网站整理(那些年的小网站)

学习网站整理 值得分享的视频博主&#xff1a;学习网站链接 百度首页的资源收藏里的截图&#xff08;排列顺序没有任何意义&#xff0c;随性而已~&#xff09;&#xff0c;可根据我标注的关键词百度搜索到这些网站呀&#xff0c;本篇末尾会一一列出来&#xff0c;供大家学习呀 …

3.3日学习打卡----初学Redis(一)

3.3日学习打卡 目录&#xff1a; 3.3日学习打卡NoSQL为什么要用NoSQL什么是NoSQL?NoSQL的四大分类关系型数据库和非关系型数据及其区别NoSQL经典应用 RedisRedis是什么?Linux下安装RedisDocker下安装Redis基本知识 NoSQL 为什么要用NoSQL 单机Mysql的美好年代 在90年代&…