```
<?php
namespace app\admin\controller;
use app\BaseController;
class Export extends BaseController
{
public function download()
{
$enToCn = [
'door_num' => '(原)门牌号',
'name' => '客户姓名',
'id_card' => '身份证号',
'phone' => '客户电话',
'type' => '用水户类型',
'waterworks' => '所属水厂',
'grid' => '所属网格',
'recorder' => '添加人员',
'township' => '乡镇/区',
'village' => '村庄',
'site' => '水表位置(经纬度)',
'ton' => '水表吨数',
'address' => '详细地址',
'pay_num' => '缴费账号',
'check_text' => '审核状态',
'create_time' => '创建时间',
]; //此数组的顺序就是Excel表格展示的顺序 key对应的是数据库字段名 value对应的是Excel的表头
$cnToEn = array_flip($enToCn);
$intToCn = array_keys($cnToEn);
$intToEn = array_keys($enToCn);
$time = input('time/s', '');
$startTime = null;
$endTime = null;
if($time) {
$startTime = explode(' - ', $time)[0];
$endTime = explode(' - ', $time)[1];
} //为防止一次性导出全表数据量过大而导出失败,加上一个时间段的筛选
$data = \app\admin\model\Payform::order('id')
->append(['site','check_text'])
->where(function ($query) use ($startTime,$endTime){
if ($startTime&&$endTime) {
$query->whereBetweenTime('create_time', $startTime, $endTime);
}
})
->select()
->toArray();
$name = "用水户信息统计表(导出)";
$excel = new \PHPExcel();
iconv('UTF-8', 'gb2312', $name); //针对中文名转码
$excel->setActiveSheetIndex(0);
$sheel = $excel->getActiveSheet();
$sheel->setTitle($name); //设置表名
$sheel->getDefaultRowDimension()->setRowHeight(14.25);//设置默认行高
$sheel->getDefaultColumnDimension()->setWidth(18);//设置默认列宽
$letterArr = ['A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','AA','AB','AC','AD','AE','AF','AG','AH','AI','AJ','AK'];
foreach ($intToEn as $k => $v) {
$sheel->setCellValue($letterArr[$k] . 1, $enToCn[$v]);
}
// 写入内容
for($i=0; $i<count($data); $i++){
$j = $i+2;
foreach ($intToEn as $k => $v) {
$sheel->setCellValue($letterArr[$k] . $j, $data[$i][$v]."\t");
}
}
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename='.$name.'.xlsx');
header('Cache-Control: max-age=0');
$objWriter = \PHPExcel_IOFactory::createWriter($excel, 'Excel2007');
$objWriter->save('php://output');
exit;
}
}
```
注意:需要安装php生成excel扩展 composer require phpoffice/phpexcel
注意:Excel表头用的数组$letterArr = \['A','B','C','D','E','F','G','H','I',....\];可以使用下面方法生成
```
function excelHead($columns) {
$array = [];
$n = 0;
for ($i = 'A'; $i <= 'Z'; $i++) {
if ($n<$columns) array_push($array, $i);
$n++;
}
return $array;
}
```
- thinkphp6执行流程(一)
- php中use关键字用法详解
- Thinkphp6使用腾讯云发送短信步骤
- 路由配置
- Thinkphp6,static静态资源访问路径问题
- ThinkPHP6.0+ 使用Redis 原始用法
- smarty在thinkphp6.0中的最佳实践
- Thinkphp6.0 搜索器使用方法
- 从已有安装包(vendor)恢复 composer.json
- tp6with的用法,表间关联查询
- thinkphp6.x多对多如何添加中间表限制条件
- thinkphp6 安装JWT
- 缓存类型
- 请求信息和HTTP头信息
- 模型事件用法
- 助手函数汇总
- tp6集成Alipay 手机和电脑端支付的方法
- thinkphp6使用jwt
- 6.0session cookie cache
- tp6笔记
- TP6(thinkphp6)队列与延时队列
- thinkphp6 command(自定义指令)
- command(自定义指令)
- 本地文件上传
- 缓存
- 响应
- 公共函数配置
- 七牛云+文件上传
- thinkphp6:访问多个redis数据源(thinkphp6.0.5 / php 7.4.9)
- 富文本编辑器wangEditor3
- IP黑名单
- 增删改查 +文件上传
- workerman 定时器操作控制器的方法
- 上传文件到阿里云oss
- 短信或者邮箱验证码防刷代码
- thinkphp6:访问redis6(thinkphp 6.0.9/php 8.0.14)
- 实现关联多个id以逗号分开查询数据
- thinkphp6实现邮箱注册功能的细节和代码(点击链接激活方式)
- 用mpdf生成pdf文件(php 8.1.1 / thinkphp v6.0.10LTS )
- 生成带logo的二维码(php 8.1.1 / thinkphp v6.0.10LTS )
- mysql数据库使用事务(php 8.1.1 / thinkphp v6.0.10LTS)
- 一,创建过滤IP的中间件
- 源码解析请求流程
- 验证码生成
- 权限管理
- 自定义异常类
- 事件监听event-listene
- 安装与使用think-addons
- 事件与多应用
- Workerman 基本使用
- 查询用户列表按拼音字母排序
- 扩展包合集
- 查询用户数据,但是可以通过输入用户昵称来搜索用户同时还要统计用户的文章和粉丝数
- 根据图片的minetype类型获取文件真实拓展名思路
- 到处excel
- 用imagemagick库生成缩略图
- 生成zip压缩包并下载
- API 多版本控制
- 用redis+lua做限流(php 8.1.1 / thinkphp v6.0.10LTS )
- 【thinkphp6源码分析三】 APP类之父, 容器Container类
- thinkphp6表单重复提交解决办法
- 小程序授权
- 最简单的thinkphp6导出Excel
- 根据访问设备不同访问不同模块
- 服务系统
- 前置/后置中间件
- 给接口api做签名验证(php 8.1.1 / thinkphp v6.0.10LTS )
- 6实现邮箱注册功能的细节和代码(点击链接激活方式)
- 使用前后端分离的验证码(thinkphp 6.0.9/php 8.0.14/vue 3.2.26)
- 前后端分离:用jwt+middleware做用户登录验证(php 8.1.1 / thinkphp v6.0.10LTS )
- vue前后端分离多图上传
- thinkphp 分组、页面跳转与ajax
- thinkphp6 常用方法文档
- 手册里没有的一些用法
- Swagger 3 API 注释
- PHP 秒级定时任务
- thinkphp6集成gatewayWorker(workerman)实现实时监听
- thinkphp6按月新增数据表
- 使用redis 实现消息队列
- api接口 统一结果返回处理类
- 使用swoole+thinkphp6.0+redis 结合开发的登录模块
- 给接口api做签名验证
- ThinkPHP6.0 + UniApp 实现小程序的 微信登录
- ThinkPHP6.0 + Vue + ElementUI + axios 的环境安装到实现 CURD 操作!
- 异常$e
- 参数请求验证自定义和异常错误自定义