Skip to content

CHICPRO

  • 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

  • php 배열 연산에서 + 와 array_merge 의 차이
  • pcntl_fork 를 이용한 다중 프로세스 실행
  • 아이폰 단축어를 이용하여 주중 공휴일엔 알람 울리지 않게 하기
  • 구글 캘린더 전체일정 재동기화
  • OpenLiteSpeed 웹서버에 HTTP 인증 적용
  • OpenLiteSpeed 웹어드민 도메인 연결
  • WireGuard를 이용한 VPN 환경 구축
  • Ubuntu 22.04 서버에 OpenLiteSpeed 웹서버 세팅
  • 맥 vim 세팅
  • 우분투 시스템 터미널쉘 zsh 로 변경

Recent Comments

  • 편리 on 업무관리용 그누보드 게시판 스킨
  • 임종섭 on 업무관리용 그누보드 게시판 스킨
  • 캐논 5D 펌웨어 | Dslr 펌웨어 업그레이드 방법 82 개의 베스트 답변 on 캐논 EOS 30D 펌웨어 Ver 1.0.6 , EOS 5D 펌웨어 Ver 1.1.1
  • Top 5 캐논 5D 펌웨어 Top 89 Best Answers on 캐논 EOS 30D 펌웨어 Ver 1.0.6 , EOS 5D 펌웨어 Ver 1.1.1
  • 편리 on 워드프레스 애니메이션 gif 파일을 mp4로 변환하여 출력하기
  • 임팀장 on 워드프레스 애니메이션 gif 파일을 mp4로 변환하여 출력하기
  • 편리 on Notepad++ NppFTP 플러그인 수동 설치
  • paul-j on Notepad++ NppFTP 플러그인 수동 설치
  • YS on Windows 10 iCloud 사진 저장 폴더 변경
  • 편리 on Docker를 이용한 Centos7 + httpd + php 5.4 개발환경 구축

Meta

  • Log in
  • Entries feed
  • Comments feed
  • WordPress.org
© 2025 CHICPRO | Built using WordPress and SuperbThemes