64 lines
2.3 KiB
PHP
64 lines
2.3 KiB
PHP
|
|
<?php
|
|||
|
|
// +----------------------------------------------------------------------
|
|||
|
|
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
|||
|
|
// +----------------------------------------------------------------------
|
|||
|
|
// | Copyright (c) 2016~2026 https://www.crmeb.com All rights reserved.
|
|||
|
|
// +----------------------------------------------------------------------
|
|||
|
|
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
|||
|
|
// +----------------------------------------------------------------------
|
|||
|
|
// | Author: CRMEB Team <admin@crmeb.com>
|
|||
|
|
// +----------------------------------------------------------------------
|
|||
|
|
|
|||
|
|
namespace app\jobs\system;
|
|||
|
|
|
|||
|
|
use crmeb\basic\BaseJobs;
|
|||
|
|
use crmeb\traits\QueueTrait;
|
|||
|
|
use crmeb\services\SpreadsheetExcelService;
|
|||
|
|
use think\facade\Log;
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 导出数据队列
|
|||
|
|
* Class ExportExcelJob
|
|||
|
|
* @package app\jobs
|
|||
|
|
*/
|
|||
|
|
class ExportExcelJob extends BaseJobs
|
|||
|
|
{
|
|||
|
|
use QueueTrait;
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 分批导出excel
|
|||
|
|
* @param $order
|
|||
|
|
* @return bool
|
|||
|
|
*/
|
|||
|
|
public function doJob(array $export = [], string $filename = '', array $header = [], array $title_arr = [], string $suffix = 'xlsx', bool $is_save = false)
|
|||
|
|
{
|
|||
|
|
if (!$export) {
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
try {
|
|||
|
|
if ($header && $title_arr) {
|
|||
|
|
$title = isset($title_arr[0]) && !empty($title_arr[0]) ? $title_arr[0] : '导出数据';
|
|||
|
|
$name = isset($title_arr[1]) && !empty($title_arr[1]) ? $title_arr[1] : '导出数据';
|
|||
|
|
$info = isset($title_arr[2]) && !empty($title_arr[2]) ? $title_arr[2] : date('Y-m-d H:i:s', time());
|
|||
|
|
SpreadsheetExcelService::instance()
|
|||
|
|
->setExcelHeader($header)
|
|||
|
|
->setExcelTile($title, $name, $info)
|
|||
|
|
->setExcelContent($export)
|
|||
|
|
->excelSave($filename, $suffix, $is_save);
|
|||
|
|
} else {
|
|||
|
|
SpreadsheetExcelService::instance()
|
|||
|
|
->setExcelContent($export)
|
|||
|
|
->excelSave($filename, $suffix, $is_save);
|
|||
|
|
}
|
|||
|
|
} catch (\Throwable $e) {
|
|||
|
|
|
|||
|
|
response_log_write([
|
|||
|
|
'message' => '导出excel' . $title . '失败,原因:' . $e->getMessage(),
|
|||
|
|
'file' => $e->getFile(),
|
|||
|
|
'line' => $e->getLine()
|
|||
|
|
]);
|
|||
|
|
}
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
}
|