엑셀 xlsx 로 저장 방법 > 그누보드5 팁자료실

그누보드5 팁자료실

엑셀 xlsx 로 저장 방법 정보

엑셀 xlsx 로 저장 방법

본문

 

GitHub - mk-j/PHP_XLSXWriter: Lightweight XLSX Excel Spreadsheet Writer in PHP

 

xlsxwriter.class.php 파일 다운받아 lib 폴더에 넣어 주세요( 이 파일만 필요합니다.)

 

아래 코드를 excel_view.php 로 저장해서 엑셀로 저장하고 싶은 데이터가 있는 스킨폴더에 복사

 

필요한 위치에 아래처럼 링크를 걸어 사용하시면 됩니다. 

현재 코드는   &wr_id=<?=$list[$i]['wr_id'] 를 이용해 wr_id 기준으로 검색하는 예시입니다.

생략하면 $bo_table 전체데이터를 저장합니다. $result 쿼리 구문도 수정해 줘야됩니다.

 

<a href="<?= $board_skin_url?>/excel_view.php?bo_table=<?=$bo_table?>&wr_id=<?=$list[$i]['wr_id']?>" class="btn_b01 btn">엑셀다운</a>

 

 


<?php
include_once('./_common.php');
set_include_path(get_include_path().PATH_SEPARATOR."..");
include_once(G5_LIB_PATH."/xlsxwriter.class.php");
 
$writer = new XLSXWriter();
 
$wr_id = isset($_GET['wr_id']) ? intval($_GET['wr_id'])  : 0;
$bot_table = $g5['write_prefix'].$bo_table;
 
$filename = "테스트신청현황.xlsx";
$filepath1 = G5_DATA_PATH.'/tmp/'.$filename;
 
$header = [];
$widths = [];
$contents = [];
 
// $header 제목명은 모두 달라야 됨, 뒤에 여러 서식을 지정할 수 있습니다.(위 github 참조) 
$header["연번"] = 'integer';
$header["예약자"] = 'string';
$header["예약일자"] = 'string';
$header["예약시간"] = 'string';
$header["전화번호"] = 'string';
$header["성별"] = 'string';
$header["요청사항"] = 'string';
$header["신청일"] = 'string';
 
//셀너비- 순서대로 알맞게 지정
$widths[] = 10; $widths[] = 20; $widths[] = 20; $widths[] = 20; $widths[] = 20; $widths[] = 20;$widths[] = 50; $widths[] = 30;
 
$styles1 = array('font'=>'맑은 고딕','font-size'=>12,'font-style'=>'bold', 'fill'=>'#ccff999', 'halign'=>'left', 'valign'=>'center', 'border'=>'left,right,top,bottom', 'widths'=>$widths);
$styles2 = array('font'=>'맑은 고딕','font-size'=>12, 'halign'=>'left', 'valign'=>'center', 'border'=>'left,right,top,bottom','wrap_text'=>true);
 
$writer->writeSheetHeader('Sheet1', $header, $styles1);    //제목줄 서식 포함
 
// 가져올 쿼리 구문
$result = sql_query("select * from {$bot_table} where wr_id = '{$wr_id}' order by wr_name");
foreach ($result as $key=>$field) {
    $contents[] = ($key + 1);
    $contents[] = $field['wr_name'];
    $contents[] = $field['wr_1'];
    $contents[] = $field['wr_2'];
    $contents[] = $field['wr_3'];
    $contents[] = $field['wr_4'];
    $contents[] = $field['wr_content'];
    $contents[] = $field['wr_last'];
    $writer->writeSheetRow('Sheet1', $contents, $styles2);
    $contents = [];
}
$writer->writeToFile($filepath1);
 
//아래부분은 수정할 필요 없습니다.
$filepath = addslashes($filepath1);
$original = urlencode($filename);
if(preg_match("/msie/i", $_SERVER["HTTP_USER_AGENT"]) && preg_match("/5\.5/", $_SERVER["HTTP_USER_AGENT"])) {
    header("content-type: doesn/matter");
    header("content-length: ".filesize("$filepath"));
    header("content-disposition: attachment; filename=\"$original\"");
    header("content-transfer-encoding: binary");
} else if (preg_match("/Firefox/i", $_SERVER["HTTP_USER_AGENT"])){
    header("content-type: file/unknown");
    header("content-length: ".filesize("$filepath"));
    header("content-disposition: attachment; filename=\"".basename($filename)."\"");
    header("content-description: php generated data");
} else {
    header("content-type: file/unknown");
    header("content-length: ".filesize("$filepath"));
    header("content-disposition: attachment; filename=\"$original\"");
    header("content-description: php generated data");
}
header("pragma: no-cache");
header("expires: 0");
flush();
$fp = fopen($filepath, "rb");
if (!fpassthru($fp)) {
    fclose($fp);
}
 
//파일 삭제
if(file_exists($filepath1)) {
    @unlink($filepath1);
}

추천
14

댓글 29개

excel_view.php  파일을 엑셀다운로드가 필요한 스킨에  넣으면 자동으로 테이블명이 입력됩니다. 검색할  부분은 상황에  맞게 수정하셔야 됩니다.  위에 링크 형식을 참고하세요.
예시는  wr_id 기준으로  검색하는 것입니다.

알려주신데로 해봤는데~~

버튼 클릭 하면 지금 이 페이지가 작동하지 않습니다. 라고 메세지가 뜨는데, 위 코드에서 변경해야 할것이 있나요?

 

wr_id와 $bo_table 확인해 보세요.

아래 구문은 목록에서 하는 링크입니다.

<a href="<?= $board_skin_url?>/excel_view.php?bo_table=<?=$bo_table?>&wr_id=<?=$list[$i]['wr_id']?>" class="btn_b01 btn">엑셀다운</a>

@자우림님 질문만으로는 원인을 알 수 없습니다.

$result = sql_query("select wr_~~~

$result 아래부분 모두 지우시고 

var_dump($result); 입력하여 내용이 나오는지 확인해 보세요.


 

  쿼리구문에  검색되는 자료가 없는것 같습니다.

Echo $wr_id;

echo $bot_table;

도 해보세요.

전체검색시

where wr_id = '{$wr_id}' 

부분은 삭제해보세요.

 

 

그누아치님 감사합니다. 너무 편리합니다^^

혹시  $contents[] = $field['mb_id']; 와 같이 처리를 할 때 mb_id의 값 대신에 mb_nick의 값으로 대체할 수 있는 방법이 있을까요? 해당 테이블에는 mb_nick의 값이 없습니다.

간단히 하면 아래처럼 하시면 되고, 아니면 위의 $result 구문을 left join 을 써서 결과값을 가져오는 방법이 있습니다.

foreach ($result as $field) {
    $result2 = sql_query("select mb_nick from g5_member where mb_id = '{$field['mb_id']}'");
    $x++;

~~~~

    $contents[] = $result2['mb_nick'];

~~~

@그누아치 질문답변에서 도움으로 join을 이용했었는데, 역시 그누아치님은 더 쉬운 방법을 제시해 주시네요.

감사합니다. ^^

전체 2,432 |RSS
그누보드5 팁자료실 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT