如何解决laravel maatwebsite/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 然后回车。
这会将配置文件复制到您的配置文件夹中。
然后从 config/excel.php 更改这一行:
excel.php
'pre_calculate_formulas' => true,// default is false
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。