微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

laravel maatwebsite/excel 公式错误意外“,”

如何解决laravel maatwebsite/excel 公式错误意外“,”

我正在从数据库获取结果,然后从中创建 Excel 表。

这会将文件存储在 storage 路径中。

public function downloadResults(array $filterarr) {
        unset($queryArr);
        $start = 0;
        $limit = 10000;
        
        $response = $this->getFilterResults($filterarr,true,$start,$limit);
        $resultHits = $response['resultHits'];
        # if results are empty,throw an exception
        if($resultHits->isEmpty())
            throw new \Exception("No results found for given filter.",1);
        
        # otherwise continue with the download process...
        $exportArr = [];
        foreach($resultHits as $key=>$value) {
            $list = (array) $value;
            array_push($exportArr,$list);
        }
        $type = 'xls';
        $export = Excel::create('result_set_download_'.time(),function($excel) use ($exportArr) {
            $excel->sheet('mysheet',function($sheet) use ($exportArr) {
                $sheet->fromArray($exportArr);
            });
        })->store($type,storage_path('app/public/exports'),true);

        return $export;
    }

如果导出和存储成功,则将存储的文件名发送回浏览器,否则发送错误消息。

try {
            $exportArr = $this->product->downloadResults($filterarr);
            $status = true;
            $jsonArr['filename'] = $exportArr['file'];            
        } catch (\Exception $e) {
            $status = false;            
            $jsonArr['message'] = $e->getMessage();            
        } finally {
            $jsonArr['success'] = $status;
            echo json_encode($jsonArr);
        }

到目前为止,这一切正常,但如果导出很少,我会收到此错误

mysheet!Z2898 -> Formula Error: Unexpected,

导出时没有进行任何计算。

我也在这里找到了一个类似的帖子 Laravel Excel Formula Error: Unexpected operator '='

这是那个帖子的答案:

// Enable calculation
$reader->calculate();

// disable calculation
$reader->calculate(false);

但我不知道把它放在哪里。

解决方法

如果你想启用任何公式,首先导出你的 laravel-excel 配置

php artisan vendor:publish

搜索Maatwebsite然后发布它。在我的例子中是 12。输入 12 然后回车。

Maatwebsite Provider

这会将配置文件复制到您的配置文件夹中。

enter image description here

然后从 config/excel.php 更改这一行:

excel.php

pre_calculate_formulas

'pre_calculate_formulas' => true,// default is false

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。