PHP laravel框架 导入导出excel ,phpexcel数据导出分多个工作区(sheet) 阿星小栈...

14 篇文章 1 订阅

laravel 导入导出有很多 但是你发现等你根据conposer安装excal的时候你发现 他总是不依不饶的提示你: 安装失败 

这就是laravel5.4的高明之处了, 下面让我们来看看吧!

1. 在laravel 项目的根目录下 我们会看到 一个composer.json的文件: 

打开, 并找到 "maatwebsite/excel": "~2.0.0" 修改为 "~2.1.0" 保存

2. 执行 composer update maatwebsite/excel

3. 编辑 laravel - config - app.php

找到 provides 的数组 在数组中添加   Maatwebsite\Excel\ExcelServiceProvider::class,

在 aliases 的数组 中 添加  'Excel'    => Maatwebsite\Excel\Facades\Excel::class,

4. 添加完成之后 执行: php artisan vendor:publish

这样就可以建路由 Controller 等

代码:

<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
use Excel;
class ExcelController extends Controller
{
    //Excel文件导出功能 By Laravel学院
    public function export(){
        $cellData = [
            ['学号','姓名','成绩'],
            ['10001','AAAAA','99'],
            ['10002','BBBBB','92'],
            ['10003','CCCCC','95'],
            ['10004','DDDDD','89'],
            ['10005','EEEEE','96'],
        ];
        Excel::create('学生成绩',function($excel) use ($cellData){
            $excel->sheet('sheetname', function($sheet) use ($cellData){
                $sheet->rows($cellData);
            });
        })->export('xls');
    }
}
若需导出分多个工作区(sheet):
  多次调用  $excel->sheet(....)  即可,注意 sheetname 避免重复
  
//导入
$filePath = 'storage/exports/'.iconv('UTF-8', 'GBK', '1234').'.xls';
        Excel::load($filePath, function($reader) {
                $data = $reader->all();
               dd($data);
});
补充:
假如项目用到时间 请修改: 根目录->config->app
 'timezone' => 'PRC',//'UTC', 为Excel的时间  //PRC为中国时间 不使用UTC的原因是因为使用date函数的时候时间不准确
假如表头是汉字 导致该列数据无法输出 请修改: 根目录->config->excel
  'to_ascii' => false  //ture 的话 Excel表头是汉字的情况下 该数值会缺失

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值