Skip to content

CHICPRO

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

PHPExcel을 이용한 다중 시트 엑셀 파일 읽기

2020-07-30 by 편리

위 이미지와 같이 두 개 이상의 시트로 구성된 엑셀 파일을 PHPExcel을 이용해 읽고 DB에 입력하는 방법이다. 아래의 코드는 모든 환경에서 정상 작동하는 코드는 아닐 수 있으며 환경에 맞게 적절하게 수정해야할 수도 있다. DB 처리는 PDO를 이용하며 관련 내용은 이 포스트를 참고하면 된다.

<?php
ini_set('memory_limit', '-1');
ini_set('max_execution_time', '0');
require './PHPExcel/PHPExcel/Classes/PHPExcel.php';
$objPHPExcel = new PHPExcel();
$file = './test.xlsx';
$objReader = PHPExcel_IOFactory::createReaderForFile($file);
$objReader->setLoadSheetsOnly(0);
$objReader->setReadDataOnly(true);
$objPHPExcel = PHPExcel_IOFactory::load($file);
$workSheetCount = $objPHPExcel->getSheetCount();
for($i = 0; $i < $workSheetCount; $i++) {
    $objPHPExcel->setActiveSheetIndex($i);
    $sheet = $objPHPExcel->getActiveSheet();
    $highestRow    = $sheet->getHighestRow();
    $highestColumn = $sheet->getHighestColumn();
    for ($k = 2; $k <= $highestRow; $k++)
    {
        $data = $sheet->rangeToArray('B' . $k . ':' . $highestColumn . $k, NULL, TRUE, FALSE);
        if (!is_array($data) || empty($data))
            continue;
        foreach ($data as $line) {
            if (!is_array($line) || empty($line))
                continue;
            foreach ($line as $v) {
                //print_r($line); exit;
                $serial = trim($v);
                if (!$serial)
                    continue;
                $sql = " insert into `data_table` ( serial ) values ( :serial ) ";
                $DB->prepare($sql);
                $DB->bindValue(':serial', $serial);
                $DB->execute();
            }
        }
    }
}

위 코드에서 5번 라인 PHPExcel.php 파일의 경로, 9번 라인 엑셀 파일의 경로, 29번 라인의 엑셀 파일에서 읽어들일 범위를 지정하는 부분 등은 직접 수정해야만 한다.

Post navigation

Previous Post:

Apache 서버의 Cache 적용하지 않기

Next Post:

영카트5 분류 순서 조정 jquery sortable 적용

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

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

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