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

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

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

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

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

程序就简单了

php 复制代码
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');
相关推荐
一只鹿鹿鹿1 分钟前
信息化项目管理规范(参考Word文件)
java·大数据·运维·开发语言·数据库
XGeFei6 分钟前
python中子线程与主线程的关系
开发语言·python
Chase_______9 分钟前
【Java杂项】final 关键字详解:变量、方法、类限制与引用可变性
java·开发语言·python
ruxingli18 分钟前
Golang iota详解
开发语言·后端·golang
我材不敲代码20 分钟前
Python venv 虚拟环境从入门到精通 + uv 高性能替代工具实战指南
开发语言·python·uv
l1t31 分钟前
DeepSeek总结的使用实体-组件-系统和基于存在性处理进行Python编程18-20
开发语言·python
磊 子38 分钟前
STL之deque和list以及两者与vector的对比
开发语言·c++·list
凤山老林39 分钟前
DDD(领域驱动设计)在复杂业务系统中的落地指南
java·开发语言·数据库·ddd·领域驱动
凯瑟琳.奥古斯特1 小时前
子查询原理与实战案例解析
开发语言·数据库·职场和发展·数据库开发
Eiceblue1 小时前
Python 操作 Excel:数据分组、分类汇总与取消分组全解
开发语言·python·excel