Yii2文章导出

该代码段展示了如何在Yii2框架中实现文章数据的导出功能。通过actionExport()方法,设置最大执行时间和内存限制,获取请求参数,调用Article模型获取导出数据。当数据量过大时,返回错误信息。然后,根据当前日期创建文件夹,使用moonlandphpexcel扩展生成Excel文件,包含文章的多种属性,如ID、标题、链接、分类、状态等,并以文本格式显示。最后,返回文件URL供下载。
摘要由CSDN通过智能技术生成
public function actionExport()
{
    //设置最大执行时间
    ini_set("max_execution_time", "360");
    ini_set('memory_limit', '256M');
    $request = Yii::$app->request;
    $where = $request->post();
    $articleModel = new Article();
    //数据
    $data = $articleModel->getExportModel($where);

    //数据量过大时禁止导出
    if(isset($data['code']) && $data['code'] == 0){
        return $this->error($data['msg']);
    }

    //导出文件名
    $fileName = date('YmdHis') . '_article_list';
    $relative_path = 'excel/' . date('Y') . '/' . date('m') . '/' . date('d') . '/';
    $absolute_path = rtrim(\Yii::$app->params['upload_dir'], '/') . '/' . $relative_path;
    if (!file_exists($absolute_path)) {
        try {
            FileHelper::createDirectory($absolute_path, 0777, true);
        } catch (\Exception $e) {
            return ['errno' => 0, 'msg' => '目录创建失败,' . $e->getMessage()];
        }
    }

    //导出设置
    \moonland\phpexcel\Excel::widget([
        'models'   => $data,
        'fileName' => $fileName,
        &#
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值