123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- <?php
- // +----------------------------------------------------------------------
- // | CatchAdmin [Just Like ~ ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2017~2020 http://catchadmin.com All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed ( https://github.com/yanwenwu/catch-admin/blob/master/LICENSE.txt )
- // +----------------------------------------------------------------------
- // | Author: JaguarJack [ njphper@gmail.com ]
- // +----------------------------------------------------------------------
- namespace catchAdmin\stations\excel;
- use catcher\base\CatchRequest as Request;
- use catchAdmin\stations\model\Station as stationModel;
- use catcher\library\excel\ExcelContract;
- use PhpOffice\PhpSpreadsheet\Style\Alignment;
- class SkExport implements ExcelContract
- {
- public $memory = '1024M';
- protected $stationModel;
- public function __construct(stationModel $stationModel)
- {
- $this->stationModel = $stationModel;
- }
- /**
- * 设置头部
- *
- * @time 2020年09月08日
- * @return string[]
- */
- public function headers(): array
- {
- // TODO: Implement headers() method.
- return [
- '学校', '建筑', '楼层', '房间', '基站名称', '基站Mac', '基站简码', '安装照片', '在线时间', '安装时间'
- ];
- }
- /**
- * 处理数据
- *
- * @time 2020年09月08日
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\DbException
- * @throws \think\db\exception\ModelNotFoundException
- * @return \think\Collection
- */
- public function sheets()
- {
- $list = $this->stationModel->getExportList();
- // var_dump($list);
- foreach ($list as &$val) {
- // $val->student_no ="\t".$val->student_no."\t";
- // $val->passive_rfid ="\t".$val->passive_rfid."\t";
- // $val->active_rfid ="\t".$val->active_rfid."\t";
- // $val->parent_phone ="\t".$val->parent_phone."\t";
- }
- return $list;
- }
- public function keys(): array
- {
- // TODO: Implement keys() method.
- return [
- 'school_name', 'building_name', 'floor_name', 'room_no', 'station_name', 'station_mac', 'station_code','install_photo','online_time','created_at'
- ];
- }
- /**
- * 设置开始行
- *
- * @time 2020年09月08日
- * @return int
- */
- public function setRow()
- {
- return 2;
- }
- /**
- * 设置标题
- *
- * @time 2020年09月08日
- * @return array
- */
- public function setTitle()
- {
- return [
- 'A1:I1', '导出室内插座', Alignment::HORIZONTAL_CENTER
- ];
- }
- /**
- * 设置宽度
- *
- * @time 2020年09月08日
- * @return array
- */
- public function setWidth()
- {
- return [
- 'A' => 20,
- 'B' => 20,
- 'C' => 20,
- 'D' => 20,
- 'E' => 20,
- 'F' => 20,
- 'G' => 20,
- 'H' => 20,
- 'I' => 20,
- 'J' => 20,
- ];
- }
- public function getWorksheet($sheet)
- {
- // $sheet->getStyle('B')->getNumberFormat()->setFormatCode(\PhpOffice\PhpSpreadsheet\Style\NumberFormat::FORMAT_TEXT);
- // $sheet->getColumnDimension('B')->setAutoSize(true);
- // $sheet->getColumnDimension('C')->setAutoSize(true);
- // $sheet->getColumnDimension('D')->setAutoSize(true);
- // $sheet->getActiveSheet()->getColumnDimension('C')->setAutoSize(true);
- // $sheet->getActiveSheet()->getColumnDimension('D')->setAutoSize(true);
- return $sheet;
- }
- }
|