Laravel에서 Excel 파일을 데이터베이스로 가져오는 방법

6374 단어 laravel


안녕하세요, Gurpreet 이 쪽에서 새로운 내용으로 다시 돌아왔습니다. 오늘 우리는 Laravel Excel이라는 패키지를 사용하여 Excel 파일을 데이터베이스로 가져오는 방법에 대해 배울 것입니다. 경우에 따라 CSV 또는 Excel 파일을 통해 일부 데이터를 삽입해야 하는 경우 이 패키지를 어떤 방식으로든 사용할 수 있습니다. 그것을 사용하는 방법에 대한 가장 중요한 부분으로 이동합시다.

내가 말했듯이 데이터베이스에서 Excel로 데이터를 내보내는 데 사용할 수 있는 것과 동일한 패키지인 데이터베이스의 Excel 파일을 통해 데이터를 가져오는 방법을 알려줄 것입니다. 어떻게 할 수 있는지 봅시다. Btw 저는 Excel을 가져오는 방법을 보여드리겠습니다.

파일 업로드 양식 만들기



먼저 모든 것을 간단하게 설명하고 Laravel 설치 및 모든 설정에 대한 사전 지식이 있다고 가정합니다. 내가 똑바로 말하면 이해하는 데 시간이 덜 걸릴 것입니다.

먼저 양식을 만들어 보겠습니다.

//You can keep this form anywhere in your blade file

<form action="{{ route('uploadusers') }}" enctype="multipart/form-data" method="POST">
                                    @csrf
                                    <div class="col-lg-12 py-3">
                                        <label for="users">Upload Users File</label>
                                        <input type="file" class="form-control" style="padding: 3px;" name="users" required />
                                        </div>
                                        <button type="submit" class="btn btn-success" name="upload">Upload</button>
                                </form>



파일 업로드 양식

양식 페이지 방문 경로 만들기



이제 양식 페이지에 방문할 수 있도록 경로를 만들어야 합니다. 또한 원하는 경우 이미지에서 이미 수행한 것처럼 이 양식에 스타일을 지정할 수 있습니다. web.php 파일에 웹 경로를 생성해 봅시다.

//for visiting the form page
Route::view('/upload-form','fileupload');

//for uploading to database
Route::post('/upload-form/fileupload',[UsersController::class,'upload'])->name('uploadusers');

//we have to create FileManagerController


컨트롤러 만들기



이제 우리가 원하는 모든 작업을 수행할 수 있도록 컨트롤러를 만들어야 합니다. 즉, Excel 파일 데이터를 데이터베이스로 가져올 수 있습니다.

우리는 아직 패키지를 설치하지 않았으며 패키지도 설치하고 그 전에 컨트롤러를 생성할 것임을 기억하십시오. 그래서 우리가 해야 할 일에 대한 분명한 비전을 갖게 됩니다.

php artisan make:controller UsersController


패키지 설치(Laravel-Excel)



이제 마지막으로 패키지를 설치하겠습니다. 그래서 패키지 이름이 무엇인지 약간의 갈등이 있습니다. 이 패키지를 설치할 때 명령에 Maatwebsite를 사용하고 그렇지 않으면 웹 사이트 이름은 La ravel-exce l 입니다. 따라서 패키지를 설치하는 방법을 살펴보겠습니다.

composer require maatwebsite/excel


Laravel 9에서 위의 명령이 실패하면 아래 명령을 사용할 수 있다고 합니다.

composer require psr/simple-cache:^2.0 maatwebsite/excel


패키지를 설치하면 서비스 공급자에 자동으로 등록됩니다. 하지만 그렇지 않다면 수동으로 하시면 큰 작업은 아닙니다. app.php의 구성으로 이동하여 공급자 배열에 나열합니다.

'providers' => [
    /*
     * Package Service Providers...
     */
    Maatwebsite\Excel\ExcelServiceProvider::class,
]

'aliases' => [
    ...
    'Excel' => Maatwebsite\Excel\Facades\Excel::class,
]


그런 다음 구성을 게시하여 완료하십시오.

php artisan vendor:publish --provider="Maatwebsite\Excel\ExcelServiceProvider" --tag=config


가져오기 클래스 만들기



패키지를 설치한 후 전체 작업을 수행할 중요한 부분으로 이동하는 것이 중요합니다. App 디렉토리에는 패키지에서 제공하는 imports 디렉토리가 있을 수 있습니다. 그렇지 않은 경우 아래 명령을 실행하여 가져오기 클래스를 만들 수 있습니다. 데이터를 가져올 때 가져오기 클래스를 만들고 데이터를 내보낼 때 내보내기 명령을 만들기 때문입니다.

php artisan make:import UsersImport --model=User


이제 App/Imports라는 파일이 UsersImports 디렉토리에 있습니다.

Excel 파일에 세 개의 필드가 있다고 가정합니다. 이름, 이메일, 비밀번호.

<?php

namespace App\Imports;

use App\Models\User;
use Illuminate\Support\Facades\Hash;
use Maatwebsite\Excel\Concerns\ToModel;

class UsersImport implements ToModel
{
    /**
    * @param array $row
    *
    * @return \Illuminate\Database\Eloquent\Model|null
    */
    public function model(array $row)
    {
        return new User([
            'name' => $row['name'],
'email'=>$row['email'],
'password'=>Hash::make($row['password']),
        ]);
    }
}



이제 Excel 파일에 3개의 필드가 있고 3개 이상이 될 수 있다고 가정했습니다. 단지 예일 뿐입니다. 또한 아래 댓글에서 경험을 공유하는 것을 잊지 않는 경우 이보다 더 복잡할 수 있습니다.

이 작업을 수행할 수 있도록 Controller의 항목을 만들어 봅시다.

컨트롤러를 통해 저장



이미 존재하는 컨트롤러에 "upload"라는 함수를 만들 것입니다.

  public function upload(Request $request)
    {
        request()->validate([
            'users' => 'required|mimes:xlx,xls|max:2048'
        ]);
        Excel::import(new UsersImport, $request->file('users'));

        return back()->with('massage', 'User Imported Successfully');
    }


또한 원하는 경우 가져온 사용자에게 다른 쿼리를 할당할 수 있고 또한 읽고 싶다면 이 웹사이트에 가입할 수 있으며 Laraveler인 경우에도 가능합니다.

결론



Excel을 통해 사용자 또는 모든 종류의 데이터를 가져올 수 있는 방법입니다. 이것은 개인적으로 프리랜서 프로젝트에서 사용했던 매우 유용한 패키지입니다. 그러한 데이터 파일을 가져오는 경우와 같이 프로젝트에서 동일한 작업을 수행하는 경우 쉽게 사용할 수 있는 것이 좋습니다.

읽어주셔서 감사합니다. 도움이 되었으면 합니다.

게시물 How to import Excel file to database in LaravelLarachamp에 처음 나타났습니다.

좋은 웹페이지 즐겨찾기