메뉴 건너뛰기

프로그램언어

조회 수 22787 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

 

 

프로그래밍을 하다보면 종종 엑셀 파일을 읽어야 하거나, 생성해야 하는 일이 생긴다.

이를 해결하기 위한 여러 방법이 있지만, 필자는 대체로 PHPExcel을 이용한다.

엑셀을 읽을때 파일을 CSV로 변환하지 않아도 되고, 엑셀 파일을 생성할때도 이상한 경고창을 볼 일도 없기 때문이다.

 

PHPExcel을 사용하기 위해서는 일단 PHP 5.2.0 이상이어야 하고, php_zip, php_xml, php_gd2가 enabled해야 된다.

그리고 소스는 http://phpexcel.codeplex.com/ 에서 다운 받으면 되고, 당연히 여러 형태의 예제 소스로 확인 할 수 있다.

 

PHPExcel을 이용하여 여러가지 형태로 활용 가능하지만 여기서는 가장 기초적인 엑셀 파일 읽기와 생성을 소개하려 한다.

 

우선 엑셀 파일 읽기 예제

<?

require_once "./PHPExcel_1.8.0/Classes/PHPExcel.php"; // PHPExcel.php을 불러와야 하며, 경로는 사용자의 설정에 맞게 수정해야 한다.

$objPHPExcel = new PHPExcel();

require_once "./PHPExcel_1.8.0/Classes/PHPExcel/IOFactory.php"; // IOFactory.php을 불러와야 하며, 경로는 사용자의 설정에 맞게 수정해야 한다.

$filename = './testA.xlsx'; // 읽어들일 엑셀 파일의 경로와 파일명을 지정한다.

try {

  // 업로드 된 엑셀 형식에 맞는 Reader객체를 만든다.

    $objReader = PHPExcel_IOFactory::createReaderForFile($filename);

    // 읽기전용으로 설정

    $objReader->setReadDataOnly(true);

    // 엑셀파일을 읽는다

    $objExcel = $objReader->load($filename);

    // 첫번째 시트를 선택

    $objExcel->setActiveSheetIndex(0);

    $objWorksheet = $objExcel->getActiveSheet();

    $rowIterator = $objWorksheet->getRowIterator();

    foreach ($rowIterator as $row) { // 모든 행에 대해서

               $cellIterator = $row->getCellIterator();

               $cellIterator->setIterateOnlyExistingCells(false); 

    }

    $maxRow = $objWorksheet->getHighestRow();

    for ($i = 0 ; $i <= $maxRow ; $i++) {

               $name = $objWorksheet->getCell('A' . $i)->getValue(); // A열

               $addr1 = $objWorksheet->getCell('B' . $i)->getValue(); // B열

               $addr2 = $objWorksheet->getCell('C' . $i)->getValue(); // C열

               $addr3 = $objWorksheet->getCell('D' . $i)->getValue(); // D열

               $addr4 = $objWorksheet->getCell('E' . $i)->getValue(); // E열

            $reg_date = $objWorksheet->getCell('F' . $i)->getValue(); // F열

               $reg_date = PHPExcel_Style_NumberFormat::toFormattedString($reg_date, 'YYYY-MM-DD'); // 날짜 형태의 셀을 읽을때는 toFormattedString를 사용한다.

      }

 catch (exception $e) {

    echo '엑셀파일을 읽는도중 오류가 발생하였습니다.';

}

?>

 

 

다음은 엑셀 파일 생성 예제

<?

$sql = " SELECT * FROM member_table";

$result = mysql_query($sql);

/** PHPExcel */

require_once "./PHPExcel_1.8.0/Classes/PHPExcel.php"; // PHPExcel.php을 불러와야 하며, 경로는 사용자의 설정에 맞게 수정해야 한다.

$objPHPExcel = new PHPExcel();

// Add some data

for ($i=1; $row=mysql_fetch_array($result); $i++)

{   

   // Add some data

   $objPHPExcel->setActiveSheetIndex(0)

               ->setCellValue("A$i", $row['name'])

               ->setCellValue("B$i", $row['address'])

               ->setCellValue("C$i", $row['phone1'])

               ->setCellValue("D$i", $row['phone2'])

               ->setCellValue("E$i", $row['item'])

               ->setCellValue("F$i",$row['count'])

               ->setCellValue("G$i", $row['req']);

}

// Rename sheet

$objPHPExcel->getActiveSheet()->setTitle('Seet name');

// Set active sheet index to the first sheet, so Excel opens this as the first sheet

$objPHPExcel->setActiveSheetIndex(0);

// 파일의 저장형식이 utf-8일 경우 한글파일 이름은 깨지므로 euc-kr로 변환해준다.

$filename = iconv("UTF-8", "EUC-KR", "테스트");

// Redirect output to a client’s web browser (Excel5)

header('Content-Type: application/vnd.ms-excel');

header("Content-Disposition: attachment;filename=".$filename.".xls");

header('Cache-Control: max-age=0');

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');

$objWriter->save('php://output');

exit;

?>

 

읽기 예제 소스는 자신의 프로그래밍 속에 끼워 넣어도 되지만,

쓰기 예제 소스는 header가 존재하기 때문에 header의 위치를 고려하여 프로그래밍 해야 할 것이다.


List of Articles
번호 제목 날짜 조회 수
160 php 내장함수 2017.03.07 17007
159 www가 붙은 도메인과 안붙은 같은 도메인, 로그인 세션 유지 2017.03.07 17080
158 PHP 날짜/시간 정리 2017.03.07 18629
157 몫과 나머지 구하기 2017.03.07 18473
156 체크박스, post 로 넘기고 받아서 다시 체크하기, checkbox 2017.03.07 21134
155 파일 이름에서 확장자 추출마스터 2017.03.07 20061
154 http://홈주소/?mode=xxx 하는방법 2017.03.07 17642
153 기본적인 페이징 2017.03.07 24849
152 PHP 속도 테스트 20 가지 2017.03.06 18306
151 POST, GET으로 배열값 받기(직렬화) file 2017.03.06 23290
150 파일 업로드 (중복처리) 2017.03.06 20185
149 간단한 PHP 파일 업로드, 다운로드 구현 2017.03.06 28549
148 다중 도메인에 따른 접속방법 2017.03.06 19370
147 네이버 지도 API 연동 PHP 소스 2017.03.06 18635
146 게시판 페이징 기법과 개념 file 2017.03.06 17323
145 PHP 도메인 이름이나 웹문서 주소 알아내기 2017.03.06 17589
144 그누보드, 여분필드 사용팁 2017.03.06 17609
143 엑셀(*.xls) 화일을 PHP에서 읽기 2017.03.06 17479
142 PHP 날짜, 시간 관련 함수. date(), mktime() 2017.03.06 16707
141 잡다한 php 2017.03.06 18502
Board Pagination Prev 1 ... 5 6 7 8 9 10 11 12 13 14 ... 17 Next
/ 17

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved