首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Laravel:用Maatwebsite导入Csv文件

Laravel:用Maatwebsite导入Csv文件
EN

Stack Overflow用户
提问于 2021-08-04 14:57:55
回答 1查看 764关注 0票数 0

我想上传一个使用Maatwebsite\Excel的csv文件。当我上传一个Excel文件时,它工作得很好,但是当我试图上传一个csv文件时,我有一个错误Undefined offset: 1

我认为问题在于csv文件的分隔符(其中分隔符是;),当var_dump($row)文件的var_dump($row)有这个结果array(3) { [0]=> string(8) "user1CSV" [1]=> string(11) "a@gmail.com" [2]=> string(9) "azerty&23" },但是对于csv文件,结果是array(1) { [0]=> string(31) "user1CSV;a1@gmail.com;azerty&23" }

如何设置分隔符以接受ExcelCsv分隔符?我的代码是:

控制器

代码语言:javascript
运行
复制
<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Maatwebsite\Excel\Facades\Excel;
use App\Imports\UsersImport;

class UserController extends Controller
{
    /**
     * @return \Illuminate\Support\Collection
     */
    public function fileImportExport()
    {
        return view('file-import');
    }

    /**
     * @return \Illuminate\Support\Collection
     */
    public function fileImport(Request $request)
    {
        Excel::import(new UsersImport, $request->file('file')->store('temp'));
        return back();
    }
}

导入类

代码语言:javascript
运行
复制
class UsersImport implements ToModel
{
    /**
    * @param array $row
    *
    * @return \Illuminate\Database\Eloquent\Model|null
    */
    public function model(array $row)
    {
        var_dump($row);
        return new User([
            'name'     => $row[0],
            'email'    => $row[1],
            'password' => Hash::make($row[2])
        ]);
    }
}

EN

Stack Overflow用户

回答已采纳

发布于 2021-08-04 15:17:43

config/excel.php文件中,可以将csv数组中的delimiter设置为;

您可以在这里查看完整的config/excel.php文件:https://github.com/Maatwebsite/Laravel-Excel/blob/3.1/config/excel.php

在第45行中有一个csv.delimiter设置,默认设置为,。您只需将其更改为; https://github.com/Maatwebsite/Laravel-Excel/blob/3.1/config/excel.php#L45

如果要为每个导入类设置自定义csv设置;正如我从Laravel文档中看到的那样,可以设置自定义csv分隔符:https://docs.laravel-excel.com/3.1/imports/custom-csv-settings.html#available-settings

app\Imports\UsersImport.php文件中,可以通过添加以下方法将delimiter设置为;

代码语言:javascript
运行
复制
public function getCsvSettings(): array
{
    return [
        'delimiter' => ";"
    ];
}
票数 1
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68653536

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档