PHPExcel을 이용한 다중 시트 엑셀 파일 읽기
위 이미지와 같이 두 개 이상의 시트로 구성된 엑셀 파일을 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번 라인의 엑셀 파일에서 읽어들일 범위를 지정하는 부분 등은 직접 수정해야만 한다.