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('score', function($sheet) use ($cellData){
- $sheet->rows($cellData);
- });
- })->export('xls');
- }
- }
- //导入
- $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
- '<span style="font-family: Arial, Helvetica, sans-serif;">to_ascii' => false //ture 的话 Excel表头是汉字的情况下 该数值会缺失</span>