Skip to content

NCUBE.NET

  • Life Log
  • Cycling Log
  • Photo Log
    • Portrait
    • Landscape
    • Flower
    • Etc
  • Coding Log
  • Information

[PHP] Spout을 이용한 엑셀 파일 데이터 읽기

2020-11-11 by 편리

그간 엑셀파일의 데이터을 읽어 처리하기 위해 PHPExcel을 사용했는데, PHPExcel 의 경우 용량이 큰 파일의 경우 처리가 되지 않거나 속도가 느린 점이 있어 Spout 를 사용해보게 됐다. 일단 사용 결과는 대 만족이다. PHPExcel 에서는 처리되지 않던 파일도 무난하게 처리가 됐고 속도도 엄청 향상됐다. 더구나 PHPExcel 은 개발이 중단된 상태이기도 하다.

개발환경이 PHP 5.6.x 버전이라서 최신 버전의 Spout를 사용할 수는 없었고 5.4 버전 이상부터 지원하는 2.7.3 버전을 사용했다. 설치를 위해 프로젝트의 composer.json 파일에 아래 내용을 추가 후 설치를 진행했다.

"box/spout": "2.7.3"

실제 엑셀파일의 데이터를 읽어들이는 코드는 아래와 같다.

<?php
ini_set('memory_limit', '-1');
ini_set('max_execution_time', '0');

$file = __DIR__.'/patent.xlsx';

use Box\Spout\Reader\ReaderFactory;
use Box\Spout\Common\Type;

$reader = ReaderFactory::create(Type::XLSX);

$reader->open($file);

foreach ($reader->getSheetIterator() as $sheet) {
    //if ($sheet->getIndex() > 0)
    //    break;
    foreach ($sheet->getRowIterator() as $row) {
        print_r($row);
    }
}

$reader->close();

만약 composer 를 사용하지 않고 직접 Spout 를 설치해서 사용하는 경우 아래와 같이 Autoload 관련 파일을 로드하는 코드를 추가해줘야 한다.

require_once '[PATH/TO]/src/Spout/Autoloader/autoload.php';

데이터를 DB에 입력하는 등의 처리는 print_r($row); 대신 해당 처리 코드를 추가해주면 된다. 만약 엑셀파일에 여러 개의 sheet 가 있을 때 첫 번째 sheet 만 처리하는 경우 예시 코드 중 아래 코드의 주석을 해제해주면 된다.

    //if ($sheet->getIndex() > 0)
    //    break;

Spout 는 PHPExcel 에 비해 제공되는 API 등이 많지 않기 때문에 불편할 수도 있으나 큰 파일의 엑셀 파일을 처리해야할 경우는 꼭 사용할 수 밖에 없을 것으로 생각된다.

Post navigation

Previous Post:

sftp를 이용한 워드프레스 플러그인 설치

Next Post:

IE11 에서 Chart.js 그래프 표시 오류 수정

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Recent Posts

  • Windows 10 메모장의 재미난 기능
  • Windows 10 iCloud 사진 저장 폴더 변경
  • VS Code에서 git 히스토리 표시 오류
  • Windows 10 iTunes 백업 폴더 변경
  • Apache 서버에서 htaccess 파일 여러 개 지정하기
  • CentOS 7에서 Apache SELinux 설정
  • PSR 코딩을위해 VS Code 에 php-cs-fixer 적용
  • Instagram Basic Display API 연동
  • phpMyAdmin에서 root 로그인이 불가능한 경우 해결법
  • Ubuntu20.04 에서 PHP8 업그레이드

Recent Comments

  • 편리 on [PHP] HTTP와 PHP를 이용한 html5 video 스트리밍 구현
  • Kim on [PHP] HTTP와 PHP를 이용한 html5 video 스트리밍 구현
  • 편리 on 워드프레스 애니메이션 gif 파일을 mp4로 변환하여 출력하기
  • 고맙습니다 on 워드프레스 애니메이션 gif 파일을 mp4로 변환하여 출력하기
  • 편리 on PHPMailer를 이용한 이메일 발송
  • 초보자 on PHPMailer를 이용한 이메일 발송
  • 편리 on PHPMailer를 이용한 이메일 발송
  • 초보자 on PHPMailer를 이용한 이메일 발송
  • 편리 on 워드프레스 굿스플로 알림톡 플러그인 개발
  • 남민기 on 워드프레스 굿스플로 알림톡 플러그인 개발

Meta

  • Log in
  • Entries feed
  • Comments feed
  • WordPress.org
© 2021 NCUBE.NET | Built using WordPress and SuperbThemes